Doctrine2:了解删除级联
为了无缝的数据库维护,通常需要在删除相应的父记录时自动删除子记录。 Doctrine2 通过“删除级联时”支持此功能,该功能可确保子记录在父记录被删除时被删除。
示例实体
考虑以下实体:
<code class="php">class Child { /** @ORM\ManyToOne(targetEntity="Father", cascade={"remove"}) */ private $father; } class Father { /** @ORM\Id @ORM\GeneratedValue */ private $id; }</code>
问题:缺少数据库级联
虽然代码通过“删除”级联在 Child 和 Father 之间建立了关系,但数据库缺少“删除时”
解决方案:数据库级级联
要实现真正的删除级联,请将 onDelete="CASCADE" 添加到子级的连接列:
<code class="php">/** @ORM\JoinColumn(name="father_id", referencedColumnName="id", onDelete="CASCADE") */</code>
这指定当从父表中删除一行时,子表中所有匹配的行将被自动删除。
注意:了解级联
请务必注意 ORM 级联和数据库级级联之间的区别。 ORM 级联在 Doctrine 的 UnitOfWork 内运行,不会影响数据库结构,而数据库级级联会在数据库中创建物理约束。在当前示例中,cascade={"remove"} 是一个 ORM 级别的级联,它将触发 UnitOfWork 中的递归删除,但不会导致所需的数据库行为。
以上是Doctrine2:如何实现删除级联以实现无缝数据库维护?的详细内容。更多信息请关注PHP中文网其他相关文章!