在带有Doctrine的Symfony 3中,我试图获得一对一的单向关系,两个表共享相同的主键。为此,我试图在Doctrine Association Mapping页面上复制该示例。
但是,一对一的uni文档没有setter和getter的例子 - 并且目标实体上也没有id字段的定义。所以我试着尝试自己。
这些是我的实体:
class Country
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", precision=0, scale=0, nullable=false, unique=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
/**
* @ORM\OneToOne(targetEntity="MySubEntity", cascade={"persist", "remove"})
* @ORM\JoinColumn(name="id", referencedColumnName="id", nullable=true)
*/
private $mysubentity;
[...]
/**
* @return MySubEntity
*/
public function getMySubEntity()
{
return $this->mysubentity;
}
/**
* @param MySubEntity $mysubentity
*/
public function setMySubEntity($mysubentity)
{
$this->mysubentity = $mysubentity;
}
}
class MySubEntity
{
/**
* @var integer
*
* @ORM\Column(name="id", type="integer", precision=0, scale=0, nullable=false, unique=false)
* @ORM\Id
* @ORM\GeneratedValue(strategy="IDENTITY")
*/
private $id;
[..]
/**
* Set id
*
* @param $id
*
* @return MySubEntity
*/
public function setId($id)
{
$this->id = $id;
return $this;
}
/**
* Get id
*
* @return int
*/
public function getId()
{
return $this->id;
}
}
当我坚持国家实体时,我会收到Integrity constraint violation: 1452 Cannot add or update a child row: a foreign key constraint fails
。在检查数据时,我可以看到Doctrine试图将MySubEntity的id设置为0.
是否有人知道我需要做什么才能从Country实体自动填充MySubEntity $ id字段?
答案 0 :(得分:4)
您需要将JoinColumn名称属性更改为其他任何内容,但不能更改为id:
/**
* @ORM\OneToOne(targetEntity="MySubEntity", cascade={"persist", "remove"})
* @ORM\JoinColumn(name="mysubentity_id", referencedColumnName="id", nullable=true)
*/
private $mysubentity;
这是做什么的: JoinColumn告诉doctrine保存关系的数据库列。因此,如果您将其称为mysub_id,则您的主实体将具有一个具有该名称的列,其中将保留referencedColumn值(您的subEntity的ID)。
如果您说JoinColumn名称是您的实体的主键已经使用的ID,那么您就会发生冲突。
编辑:
我错过了共享相同主键的观点。这有什么具体原因吗? 但是,如果您真的需要这样做是为了遗留原因,请查看
或者通过更改生成策略(在这种情况下为NONE或custom)自行生成subEntity的主键值的可能性