SonataUserBundle + FOSUserBundle 注解问题 Doctrine Primary Key Error
SonataUserBundle + FOSUserBundle Annotation Issue Doctrine Primary Key Error
使用 Symfony 4.1、Sonata 用户包 4.x 和 FOSUserBundle 2.1.2。
我正在尝试覆盖用户和组 table 的 table 名称。因此,我为自动生成的用户和组添加了注释 类:
use Sonata\UserBundle\Entity\BaseGroup as BaseGroup;
use Doctrine\ORM\Mapping as ORM;
/**
* This file has been generated by the SonataEasyExtendsBundle.
* @ORM\Entity()
* @ORM\Table(name="aegis_group")
* @link https://sonata-project.org/easy-extends
* References:
* @link http://www.doctrine-project.org/projects/orm/2.0/docs/reference/working-with-objects/en
*/
class Group extends BaseGroup
{
/**
* @ORM\Id
* @var int $id
*/
protected $id;
/**
* Get id.
*
* @return int $id
*/
public function getId()
{
return $this->id;
}
}
然后我修改了 doctrine.yaml 以考虑这些注释:
mappings:
App:
is_bundle: false
type: annotation
dir: '%kernel.project_dir%/src/Entity'
prefix: 'App\Entity'
alias: App
FOSUserBundle: ~
ApplicationSonataUserBundle:
type: annotation
SonataUserBundle: ~
然而,当我运行迁移时,学说给我一个错误:
In MappingException.php line 46:
No identifier/primary key specified for Entity
"App\Application\Sonata\User Bundle\Entity\Group" sub class of
"Sonata\UserBundle\Entity\BaseGroup". Every Entity must have an
identifier/primary key.
如何解决这个问题,以便我可以使用自己的自定义 table 名称?我只想更改数据库 table 名称,这不应该是这样。
首先,您忘记了 class 中的命名空间。
其次:尝试为您的主键添加策略和列,例如
/**
* @var int $id
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
好吧,原来 XML orm 文件是由 SonataEasyExtendsBundle 在目录 Application\Sonata\UserBundle\Resources\config\doctrine 文件夹中生成的。应该修改此文件 (User.orm.xml) 以更改 table 配置。
<?xml version="1.0" encoding="UTF-8"?>
<doctrine-mapping xmlns="http://doctrine-project.org/schemas/orm/doctrine-mapping"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://doctrine-project.org/schemas/orm/doctrine-mapping
http://doctrine-project.org/schemas/orm/doctrine-mapping.xsd">
<entity name="App\Application\Sonata\UserBundle\Entity\User" table="aegis_user">
<id name="id" column="id" type="integer">
<generator strategy="AUTO" />
</id>
</entity>
</doctrine-mapping>
使用 Symfony 4.1、Sonata 用户包 4.x 和 FOSUserBundle 2.1.2。
我正在尝试覆盖用户和组 table 的 table 名称。因此,我为自动生成的用户和组添加了注释 类:
use Sonata\UserBundle\Entity\BaseGroup as BaseGroup;
use Doctrine\ORM\Mapping as ORM;
/**
* This file has been generated by the SonataEasyExtendsBundle.
* @ORM\Entity()
* @ORM\Table(name="aegis_group")
* @link https://sonata-project.org/easy-extends
* References:
* @link http://www.doctrine-project.org/projects/orm/2.0/docs/reference/working-with-objects/en
*/
class Group extends BaseGroup
{
/**
* @ORM\Id
* @var int $id
*/
protected $id;
/**
* Get id.
*
* @return int $id
*/
public function getId()
{
return $this->id;
}
}
然后我修改了 doctrine.yaml 以考虑这些注释:
mappings:
App:
is_bundle: false
type: annotation
dir: '%kernel.project_dir%/src/Entity'
prefix: 'App\Entity'
alias: App
FOSUserBundle: ~
ApplicationSonataUserBundle:
type: annotation
SonataUserBundle: ~
然而,当我运行迁移时,学说给我一个错误:
In MappingException.php line 46:
No identifier/primary key specified for Entity "App\Application\Sonata\User Bundle\Entity\Group" sub class of "Sonata\UserBundle\Entity\BaseGroup". Every Entity must have an identifier/primary key.
如何解决这个问题,以便我可以使用自己的自定义 table 名称?我只想更改数据库 table 名称,这不应该是这样。
首先,您忘记了 class 中的命名空间。
其次:尝试为您的主键添加策略和列,例如
/**
* @var int $id
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
好吧,原来 XML orm 文件是由 SonataEasyExtendsBundle 在目录 Application\Sonata\UserBundle\Resources\config\doctrine 文件夹中生成的。应该修改此文件 (User.orm.xml) 以更改 table 配置。
<?xml version="1.0" encoding="UTF-8"?>
<doctrine-mapping xmlns="http://doctrine-project.org/schemas/orm/doctrine-mapping"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://doctrine-project.org/schemas/orm/doctrine-mapping
http://doctrine-project.org/schemas/orm/doctrine-mapping.xsd">
<entity name="App\Application\Sonata\UserBundle\Entity\User" table="aegis_user">
<id name="id" column="id" type="integer">
<generator strategy="AUTO" />
</id>
</entity>
</doctrine-mapping>