>데이터 베이스 >MySQL 튜토리얼 >PostgreSQL에서 RETURNING을 사용하여 여러 INSERT 문을 효율적으로 연결하려면 어떻게 해야 합니까?

PostgreSQL에서 RETURNING을 사용하여 여러 INSERT 문을 효율적으로 연결하려면 어떻게 해야 합니까?

Mary-Kate Olsen
Mary-Kate Olsen원래의
2024-12-31 10:52:09565검색

How Can I Efficiently Chain Multiple INSERT Statements with RETURNING in PostgreSQL?

PostgreSQL에서 RETURNING을 사용하여 여러 INSERT 연결

계층적 데이터베이스 구조로 작업할 때 종속성이 있는 여러 테이블에 데이터를 삽입해야 하는 경우가 많습니다. PostgreSQL에서는 데이터 수정 CTE와 RETURNING 절의 조합이 효율적인 솔루션을 제공합니다.

상위 테이블 table1에 새 행을 삽입하고 하위 테이블 table2 및 table3에 관련 행을 채우려면 다음을 따르세요. 단계:

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;

CTE 분석 체인:

  • 첫 번째 CTE인 ins1은 table1에 새 행을 삽입하고 생성된 user_id를 반환합니다.
  • 두 번째 CTE인 ins2는 해당 행을 table2에 삽입합니다. ins1에서 반환된 user_id를 사용합니다.
  • 마지막 INSERT 문은 ins1의 user_id를 사용합니다. table3에 행을 삽입합니다. 선택적 RETURNING 절은 일반적으로 시퀀스 또는 기본값에서 결과 user_id를 반환합니다.

데이터 수정 CTE 사용의 이점:

  • 삽입 연결: CTE를 사용하면 여러 INSERT 문을 연결하여 다음을 보장할 수 있습니다. 올바른 작업 순서.
  • 단순성: WITH CTE를 사용하면 쿼리의 읽기 쉽고 유지 관리가 더 쉬워집니다.
  • 효율성: CTE를 사용하면 향상될 수 있습니다. INSERT 문의 실행 순서를 최적화하여 성능을 향상시켰습니다.

위 내용은 PostgreSQL에서 RETURNING을 사용하여 여러 INSERT 문을 효율적으로 연결하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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