我尝试使用@MappedSuperclass。它适用于简单变量(int、string...)和 OneToMany/ManyToOne 关系。但是 OneToOne 关系不起作用。
我有两个具有 OneToOne 关系的 MappedSuperclass:_SiteUser
/**
* @MappedSuperclass _SiteUser
*
* @ORM\Entity(repositoryClass="_SiteModule\_Repository\_SiteUserRepository")
* @ORM\Table(name="site_users")
*/
class _SiteUser
{
/**
* @var int
* @Groups("id")
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var string
* @Groups({"username"})
*
* @ORM\Column(name="username", type="string", length=255, unique=true)
*/
protected $username;
/**
* @var string
* @Groups({"password"})
*
* @ORM\Column(name="password", type="string", length=255)
*/
protected $password;
/**
* @var _SiteUserTo
*
* @ORM\OneToOne(targetEntity="_SiteModule\_Entity\_SiteUserTo", mappedBy="user")
* @Gedmo\Versioned()
*/
protected $user_to;
_SiteUserTo
/**
* @MappedSuperclass _SiteUserTo
*
* @ORM\Entity(repositoryClass="_SiteModule\_Repository\_SiteUserToRepository")
* @ORM\Table(name="users_to")
*/
class _SiteUserTo
{
/**
* @var int
* @Groups("id")
*
* @ORM\Column(name="id", type="integer")
* @ORM\Id
* @ORM\GeneratedValue(strategy="AUTO")
*/
protected $id;
/**
* @var _SiteUser
*
* @ORM\OneToOne(targetEntity="_SiteModule\_Entity\_SiteUser", inversedBy="user_to")
* @JoinColumn(name="user_id", referencedColumnName="id")
*/
protected $user;
这是我扩展这些 MappedSuperclass 的 2 类:SiteUser
/**
* SiteUser
*
* @ORM\Entity(repositoryClass="SiteModule\Repository\SiteUserRepository")
* @ORM\Table(name="site_users")
*/
class SiteUser extends _SiteUser
{
}
站点用户至
/**
* SiteUserTo
*
* @ORM\Entity(repositoryClass="SiteModule\Repository\SiteUserToRepository")
* @ORM\Table(name="users_to")
*/
class SiteUserTo extends _SiteUserTo
{
}
当我从 MappedSuperclass(_SiteUser 和 _SiteUserTo)生成实体时,我得到了一个名为“users_to”的表,其中包含 id 和 user_id。但是当我从其他类(SiteUser 和 SiteUserTo)生成实体时,它会创建只有 id 字段的表“users_to”。我不知道为什么...
如果我像这样更新我的 SiteUser 类:
/**
* Class SiteUser
*
* @ORM\Entity(repositoryClass="SiteModule\Repository\SiteUserRepository")
* @ORM\Table(name="site_users")
*/
class SiteUser extends _SiteUser
{
/**
* @var boolean
*
* @ORM\Column(name="test", type="boolean")
*/
protected $test;
/**
* @var SiteUserTo
*
* @ORM\OneToOne(targetEntity="SiteModule\Entity\SiteUserTo", mappedBy="user")
*/
protected $user_to;
}
和 SiteUserTo 喜欢这样:
/**
* Class SiteUserTo
*
* @ORM\Entity(repositoryClass="SiteModule\Repository\SiteUserToRepository")
* @ORM\Table(name="users_to")
*/
class SiteUserTo extends _SiteUserTo
{
/**
* @var boolean
*
* @ORM\Column(name="test", type="boolean")
*/
protected $test;
/**
* @var SiteUser
*
* @ORM\OneToOne(targetEntity="SiteModule\Entity\SiteUser", inversedBy="user_to")
* @JoinColumn(name="user_id", referencedColumnName="id")
*/
protected $user;
}
我遇到了同样的问题,user_id
表中没有字段users_to
。但是“测试”字段在表格site_users
和表格中创建得很好users_to
......