使用Symfony 4.1,Sonata User Bundle 4.x和FOSUserBundle 2.1.2。
我正在尝试覆盖User和Group表的表名。因此,我在自动生成的用户和组类中添加了注释:
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: ~
但是,当我运行迁移时,学说给了我一个错误:
在MappingException.php第46行中:
未为实体指定标识符/主键 的“ App \ Application \ Sonata \ User Bundle \ Entity \ Group”子类 “ Sonata \ UserBundle \ Entity \ BaseGroup”。每个实体必须有一个 标识符/主键。
如何解决此问题,以便可以使用自己的自定义表名?我要做的就是更改数据库表名,这不应该涉及到这一点。
答案 0 :(得分:0)
首先,您忘记了类中的命名空间。
第二:尝试为您的主键添加策略和列,例如
/**
* @var int $id
* @ORM\Id
* @ORM\Column(type="integer")
* @ORM\GeneratedValue(strategy="AUTO")
*/
答案 1 :(得分:0)
好吧,事实证明SonataEasyExtendsBundle在目录Application \ Sonata \ UserBundle \ Resources \ config \ doctrine文件夹中生成了一个XML orm文件。应该修改此文件(User.orm.xml)以更改表配置。
<?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>