>데이터 베이스 >MySQL 튜토리얼 >자식이 참조하지 않을 때 PostgreSQL에서 부모 삭제를 보장하는 방법은 무엇입니까?

자식이 참조하지 않을 때 PostgreSQL에서 부모 삭제를 보장하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-29 15:41:02906검색

How to Ensure Parent Deletion in PostgreSQL When No Children Reference It?

어떤 하위 항목도 참조하지 않을 때 상위 삭제 보장>

하위 행을 삭제할 때 다음과 같이 상위 항목을 삭제해야 하는 경우가 많습니다. 글쎄요, 다른 어린이가 더 이상 참조하지 않는다면 말이죠. 이는 데이터 수정 CTE를 사용하여 PostgreSQL에서 달성할 수 있으며 경합 조건의 위험을 최소화합니다.

다음 PostgreSQL 문을 고려하세요.

<code class="sql">WITH del_child AS (
    DELETE FROM child
    WHERE  child_id = 1
    RETURNING parent_id, child_id
    )
DELETE FROM parent p
USING  del_child x
WHERE  p.parent_id = x.parent_id
AND    NOT EXISTS (
   SELECT FROM child c
   WHERE  c.parent_id = x.parent_id
   AND    c.child_id <> x.child_id   -- !
   );</code>

작동 방식은 다음과 같습니다.

  • del_child CTE는 child_id = 1인 하위 행을 삭제합니다.
  • DELETE 문은 del_child에서 반환된 parent_id를 기반으로 상위 행을 삭제하려고 시도합니다. 그러나 참조하는 다른 하위 항목이 없는 경우에만 상위 항목을 삭제합니다. 이는 다른 child_id를 가진 다른 하위 쿼리가 있는지 확인하여 수행됩니다(NOT EXISTS 하위 쿼리).
  • 조건 c.child_id <> x.child_id는 하위 쿼리가 방금 삭제된 하위 행을 제외하도록 보장합니다.

Eliminating Race Conditions

경쟁 조건의 가능성을 완전히 제거하려면 , 하위 행과 상위 행을 모두 삭제하기 전에 상위 행을 잠그는 것이 좋습니다. 이렇게 하면 한 번에 하나의 트랜잭션만 이 작업을 처리할 수 있으므로 여러 트랜잭션이 하위 항목을 삭제하고 상위 항목을 고아로 남겨 두는 것을 방지할 수 있습니다.

행 잠금이 포함된 업데이트된 명령문은 다음과 같습니다.

<code class="sql">WITH lock_parent AS (
   SELECT p.parent_id, c.child_id
   FROM   child  c
   JOIN   parent p ON p.parent_id = c.parent_id
   WHERE  c.child_id = 12              -- provide child_id here once
   FOR    NO KEY UPDATE                -- locks parent row.
   )
 , del_child AS (
   DELETE FROM child c
   USING  lock_parent l
   WHERE  c.child_id = l.child_id
   )
DELETE FROM parent p
USING  lock_parent l
WHERE  p.parent_id = l.parent_id
AND    NOT EXISTS (
   SELECT FROM child c
   WHERE  c.parent_id = l.parent_id
   AND    c.child_id <> l.child_id   -- !
   );</code>

위 내용은 자식이 참조하지 않을 때 PostgreSQL에서 부모 삭제를 보장하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.