> 데이터 베이스 > MySQL 튜토리얼 > PostgreSQL CTE 및 INSERT...RETURNING이 어떻게 상위 및 하위 테이블에 데이터를 효율적으로 삽입할 수 있습니까?

PostgreSQL CTE 및 INSERT...RETURNING이 어떻게 상위 및 하위 테이블에 데이터를 효율적으로 삽입할 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-30 11:26:11
원래의
921명이 탐색했습니다.

How Can PostgreSQL CTEs and INSERT...RETURNING Efficiently Insert Data into Parent and Child Tables?

PostgreSQL의 INSERT...RETURNING 및 CTE를 사용하여 하위 테이블에 여러 값 삽입

상위 테이블에서 새로 추출된 user_id를 삽입하려면 table1 하위 테이블 table2 및 table3에 PostgreSQL은 데이터 수정 공통 테이블 표현식을 사용하여 우아한 솔루션을 제공합니다. (CTE).

CTE를 사용하면 여러 개의 INSERT 문을 연결하여 단일 트랜잭션에서 여러 작업을 실행할 수 있습니다.

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;
로그인 후 복사

이 코드는 단계별 프로세스를 따릅니다.

  1. ins1: table1에 새 행을 삽입하고 새로 생성된 행을 검색합니다. RETURNING을 사용하는 user_id입니다. 이 단계에서는 하위 테이블 간의 연결을 설정합니다.
  2. ins2: ins1의 user_id를 비밀번호와 함께 table2에 삽입합니다.
  3. 다음을 사용하여 ins1의 user_id를 table3에 삽입합니다. 주소, 도시 등의 추가 데이터 전화.

핵심 사항:

  • 데이터 무결성을 보장하기 위해 INSERT에 대한 열 정의 목록을 제공하는 것이 좋습니다.
  • 기본값이 자동으로 삽입되므로 INSERT에서 기본값이 있는 열을 생략할 수 있습니다.
  • 세 번째 INSERT 문의 마지막 RETURNING 절은 table3의 user_id를 반환하지만 일반적으로 table1의 user_id와 동일합니다.
  • 데이터 수정 CTE를 사용하면 여러 INSERT 및 기타 항목을 연결할 수 있습니다. 데이터 조작 작업을 단일 트랜잭션으로 통합합니다.

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

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿