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

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

Barbara Streisand
풀어 주다: 2024-12-29 15:54:12
원래의
1016명이 탐색했습니다.

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>
<div class="code" style="position:relative; padding:0px; margin:0px;"><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>
<div class="code" style="position:relative; padding:0px; margin:0px;"><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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
이전 기사:동일하고 모호한 열이 있는 여러 테이블에서 데이터를 선택하는 방법은 무엇입니까? 다음 기사:Java ReadyStatements에서 열 이름을 입력 매개변수로 사용할 수 있습니까?
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
최신 이슈
관련 주제
더>
인기 추천
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿