使用 Doctrine2 了解刪除級聯
Doctrine2 在處理相關實體時提供了設定級聯行為的彈性。然而,一個常見的誤解是,在實體關聯中設定cascade={"remove"}會自動將ON DELETE CASCADE選項新增至資料庫中的外鍵列。
在Doctrine2中,有兩種不同的型別級聯數量:
1。 ORM 層級:
2.資料庫級聯:
問題中提供的範例使用 ORM 級聯。雖然在刪除父對象時它會正確刪除關聯的子對象,但它不會在資料庫中建立 ON DELETE CASCADE 選項。為此,需要進行以下修改:
<code class="php">/** * @ORM\ManyToOne(targetEntity="Father", cascade={"remove"}) * * @ORM\JoinColumns({ * @ORM\JoinColumn(name="father_id", referencedColumnName="id", onDelete="CASCADE") * }) * * @var Father */ private $father;</code>
需要注意的是,像範例中那樣使用 ORM 級聯將導致在刪除子物件時刪除父物件。這可能不是預期的行為。
以上是Doctrine2 如何使用 ON DELETE CASCADE 處理連鎖行為?的詳細內容。更多資訊請關注PHP中文網其他相關文章!