"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > SQL Server 업데이트 트리거에서 수정 된 필드 만 효율적으로 검색하는 방법은 무엇입니까?

SQL Server 업데이트 트리거에서 수정 된 필드 만 효율적으로 검색하는 방법은 무엇입니까?

2025-03-22에 게시되었습니다
검색:461

How to Efficiently Retrieve Only Modified Fields from an SQL Server Update Trigger?

접근법

옵션 1 : 동적 SQL (선언 접근법)

를 사용하여 수정 된 열 값을 추출하는 코드를 구축합니다. 그러나 테이블에 많은 열이 있다면이 접근법은 지루할 수 있습니다.

옵션 2 : 비 삽입 및 결합 (비정상적인 접근)

삽입 된 테이블과 다재다능한 테이블을 모두 제작하는 것입니다. 이 두 테이블에 합류하면 FieldValue가 변경된 행을 식별 할 수있어 수정 된 값을 제공합니다.

CREATE TRIGGER TriggerName ON dbo.Sample_Table FOR DELETE, INSERT, UPDATE AS
BEGIN
    SET NOCOUNT ON;

    -- Unpivot deleted
    WITH deleted_unpvt AS (
        SELECT ContactID, FieldName, FieldValue
        FROM (SELECT ContactID, Forename, Surname, Extn, Email, Age FROM deleted) p
        UNPIVOT (FieldValue FOR FieldName IN (Forename, Surname, Extn, Email, Age)) AS deleted_unpvt
    ),
    -- Unpivot inserted
    inserted_unpvt AS (
        SELECT ContactID, FieldName, FieldValue
        FROM (SELECT ContactID, Forename, Surname, Extn, Email, Age FROM inserted) p
        UNPIVOT (FieldValue FOR FieldName IN (Forename, Surname, Extn, Email, Age)) AS inserted_unpvt
    )

    -- Join them and identify changes
    INSERT INTO Sample_Table_Changes (ContactID, FieldName, FieldValueWas, FieldValueIs)
    SELECT Coalesce(D.ContactID, I.ContactID) ContactID,
           Coalesce(D.FieldName, I.FieldName) FieldName,
           D.FieldValue AS FieldValueWas,
           I.FieldValue AS FieldValueIs
    FROM deleted_unpvt D
    FULL OUTER JOIN inserted_unpvt I
        ON D.ContactID = I.ContactID AND D.FieldName = I.FieldName
    WHERE D.FieldValue  I.FieldValue
    OR (D.FieldValue IS NOT NULL AND I.FieldValue IS NULL)
    OR (D.FieldValue IS NULL AND I.FieldValue IS NOT NULL);
    
    -- Use the contents of Sample_Table_Changes for replication
END
GO
다음 코드를 고려하십시오. 시작하다 Nocount를 설정하십시오. - 비트 비트가 삭제되었습니다 deleted_unpvt as ( ContactID, FieldName, FieldValue를 선택하십시오 from (select contactId, forename, surname, extn, 이메일, 삭제 나이) p. UNPIVOT (fieldName의 FieldValue in (Forename, Surname, extn, 이메일, Age)) as deleted_unpvt ),) - 삽입되지 않은 삽입 inserted_unpvt as ( ContactID, FieldName, FieldValue를 선택하십시오 from (select contactId, forename, surname, extn, 이메일, 삽입 나이) p. inserted_unpvt as )) - 참여하고 변경 사항을 식별하십시오 sample_table_changes에 삽입 (ContactID, FieldName, FieldValuewas, FieldValueis) Coalesce (D.Contactid, I.Contactid) ContactID, ContactID, Coalesce (D.FieldName, I.FieldName) FieldName, FieldValuewas로 D.FieldValue, I. FieldValueis로서 필드 value deleted_unpvt에서 d 전체 외부 조인 inserted_unpvt i d.contactid = i.contactid 및 d.fieldname = i.fieldname에서 여기서 d.fieldValue I.FieldValue 또는 (D.FieldValue는 NULL이 아니며 I.FieldValue는 Null입니다) 또는 (d.fieldValue는 null이고 i.fieldValue는 null이 아닙니다); - 복제를 위해 sample_table_changes의 내용을 사용하십시오 끝

이 비정상적인 접근 방식은 복잡한 동적 SQL을 사용하거나 비트 필드 산술 오버플로 문제를 사용하지 않고 효과적으로 변경, 삭제 및 삽입을 처리합니다. 또한 추가 안내 열이 식별에 사용되는 한 자연 기본 키의 변화에도 영향을받지 않습니다.

최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3