>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL의 CTE는 다중 테이블 업데이트에 대한 RETURNING을 사용하여 다중 INSERT를 어떻게 효율적으로 처리할 수 있습니까?

PostgreSQL의 CTE는 다중 테이블 업데이트에 대한 RETURNING을 사용하여 다중 INSERT를 어떻게 효율적으로 처리할 수 있습니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2025-01-02 14:05:40922검색

How Can PostgreSQL's CTEs Efficiently Handle Multiple INSERTs with RETURNING for Multi-Table Updates?

PostgreSQL의 다중 테이블 업데이트에 대한 다중 삽입...RETURNING

새로 삽입된 데이터를 참조하면서 여러 하위 테이블에 데이터 삽입 부모 테이블은 어려운 작업이 될 수 있습니다. 이러한 맥락에서 PostgreSQL은 데이터 수정 공통 테이블 표현식(CTE)을 사용하여 강력한 솔루션을 제공합니다.

처음에는 RETURNING 절을 사용하여 상위 테이블에 새로 삽입된 행의 user_id를 검색할 수 있습니다.

INSERT INTO table1 (default,'johnee','john','smith',default) RETURNING userid;

여러 INSERT를 수행하기 위해 데이터 수정 CTE를 다음과 같이 활용할 수 있습니다. 다음은 다음과 같습니다.

WITH ins1 AS (
   INSERT INTO table1 (username, name, surname)
   VALUES ('johnee','john','smith')
   RETURNING user_id
   )
, ins2 AS (
   INSERT INTO table2 (user_id, password)
   SELECT ins1.user_id, 'secret'
   FROM ins1
   )
INSERT INTO table3 (user_id, adress, city, phone)
SELECT ins1.user_id, ...
FROM ins1
RETURNING user_id;

이 코드에서 ins1 CTE는 table1에 INSERT를 수행하고 user_id를 반환합니다. 그런 다음 ins2 CTE는 ins1의 user_id를 사용하여 table2에 데이터를 삽입합니다. 마지막으로 세 번째 INSERT는 ins1의 user_id를 사용하여 table3에 데이터를 삽입하고 선택적으로 결과 user_id를 반환합니다.

데이터 수정 CTE를 사용하면 여러 INSERT를 효율적으로 연결할 수 있으며 새로 삽입된 데이터가 하위 테이블에 있는지 확인할 수 있습니다. 테이블은 상위 테이블과 필요한 관계를 유지합니다.

위 내용은 PostgreSQL의 CTE는 다중 테이블 업데이트에 대한 RETURNING을 사용하여 다중 INSERT를 어떻게 효율적으로 처리할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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