집 >데이터 베이스 >MySQL 튜토리얼 >PostgreSQL의 CTE는 다중 테이블 업데이트에 대한 RETURNING을 사용하여 다중 INSERT를 어떻게 효율적으로 처리할 수 있습니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!