>데이터 베이스 >MySQL 튜토리얼 >MERGE 문은 SQL Server INSERT 작업에서 생성된 ID 및 원본 데이터를 어떻게 검색할 수 있나요?

MERGE 문은 SQL Server INSERT 작업에서 생성된 ID 및 원본 데이터를 어떻게 검색할 수 있나요?

Barbara Streisand
Barbara Streisand원래의
2024-12-29 15:54:121005검색

How Can MERGE Statement Retrieve Generated Identity and Source Data in SQL Server INSERT Operations?

삽입... 병합... 선택: MERGE를 활용하여 생성된 ID 검색

SQL Server에서 INSERT... SELECT 문을 사용하면 다른 테이블이나 쿼리에서 대상 테이블로 데이터를 삽입할 수 있습니다. 그러나 여러 소스에서 값을 추출하는 데에는 한계가 있습니다. 삽입된 데이터와 원본 데이터를 모두 검색할 수 있는 MERGE 문을 사용하면 해결 방법이 있습니다.

설명하기 위해 다음 상황을 고려합니다.

INSERT INTO Table3(Column2, 컬럼3, 컬럼4, 컬럼5)<br>SELECT null, 110, Table1.ID, Table2.Column2<br>FROM Table1</p>
<pre class="brush:php;toolbar:false"> JOIN Table1Table2Link on Table1.ID=Table1Table2Link.Column1
 JOIN Table2 on Table1Table2Link.Column2=Table2.ID

Table3 및 Table2.ID에서 생성된 ID(Inserted.ID)를 캡처하여 삽입해야 할 필요성이 발생합니다. 임시 테이블이나 변수에 넣습니다. OUTPUT 절은 이러한 목적으로 일반적으로 사용되지만 다른 테이블에서 데이터를 추출할 수는 없습니다.

해결책은 INSERT...SELECT 대신 MERGE를 사용하여 테이블을 채우는 것입니다. 이를 통해 출력 절에 삽입된 값과 소스 값 모두에 액세스할 수 있습니다.

MERGE INTO Table3 USING<br>(</p>
<pre class="brush:php;toolbar:false">SELECT null as col2, 
       110 as col3, 
       Table1.ID as col4, 
       Table2.Column2 as col5,
       Table2.Id as col6
FROM Table1
JOIN Table1Table2Link on Table1.ID=Table1Table2Link.Column1
JOIN Table2 on Table1Table2Link.Column2=Table2.ID

) AS s ON 1 = 0 -- 항상 일치하지 않음
WHEN NOT MATCHED THEN
INSERT(Column2, Column3, Column4, Column5)
VALUES (s.col2, s.col3, s.col4, s.col5)
OUTPUT Inserted.ID, s.col6
INTO @MyTableVar (insertedId, Table2Id);

MERGE를 사용하면 OUTPUT 절에서 삽입된 ID(Inserted.ID)와 Table2(Table2.ID)의 값을 모두 가져와 추가 작업을 위해 @MyTableVar에 삽입할 수 있습니다. 처리중입니다.

위 내용은 MERGE 문은 SQL Server INSERT 작업에서 생성된 ID 및 원본 데이터를 어떻게 검색할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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