学说一对一单向

时间:2017-04-27 10:20:41

标签: php symfony doctrine-orm orm

在带有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字段?

1 个答案:

答案 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,那么您就会发生冲突。

编辑:

我错过了共享相同主键的观点。这有什么具体原因吗? 但是,如果您真的需要这样做是为了遗留原因,请查看

http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/tutorials/composite-primary-keys.html#use-case-2-simple-derived-identity

或者通过更改生成策略(在这种情况下为NONE或custom)自行生成subEntity的主键值的可能性

http://docs.doctrine-project.org/projects/doctrine-orm/en/latest/reference/basic-mapping.html#identifier-generation-strategies