Heim >Datenbank >MySQL-Tutorial >Wie können geänderte Felder in SQL Server-UPDATE-Triggern mithilfe von XML oder alternativen Methoden effizient erfasst werden?

Wie können geänderte Felder in SQL Server-UPDATE-Triggern mithilfe von XML oder alternativen Methoden effizient erfasst werden?

DDD
DDDOriginal
2024-12-23 12:56:16894Durchsuche

How to Efficiently Capture Modified Fields in SQL Server UPDATE Triggers Using XML or Alternative Methods?

Effizienter Update-Trigger zum Erfassen geänderter Felder in SQL Server

Problem:

Die COLUMNS_UPDATED-Methode ist bekannt, aber a Es ist eine schnellere Technik erforderlich, um geänderte Feldwerte in einem XML-Format für die Replikation zu erfassen Zwecke.

Automatisierte Routineabfrage:

CREATE TRIGGER DBCustomers_Insert
    ON DBCustomers
    AFTER UPDATE
AS
BEGIN
    DECLARE @sql as NVARCHAR(1024);
    SET @sql = 'SELECT ';


    -- HELP NEEDED FOR FOLLOWING LINE...
    -- I can manually write every column, but need an automated way that works with any column specifications
    for each column, if its modified append $sql = ',' + columnname...

    SET @sql = $sql + ' FROM inserted FOR XML RAW';

    DECLARE @x as XML;
    SET @x = CAST(EXEC(@sql) AS XML);


    .. use @x

END

Alternative Lösung:

Anstelle der Verwendung von COLUMNS_UPDATED wird diese Antwort angezeigt eine alternative Methode, die das Problem angeht. Dazu gehört das Aufheben der Pivotierung sowohl der eingefügten als auch der gelöschten Tabellen, um Schlüssel-, Feldwert- und Feldnamenspalten zu erstellen. Durch das Zusammenführen und Filtern dieser beiden nichtpivotierten Tabellen werden nur die geänderten, gelöschten und eingefügten Zeilen identifiziert.

Beispiel:

-- Setup tables and data
CREATE TABLE dbo.Sample_Table (ContactID int, Forename varchar(100), Surname varchar(100), Extn varchar(16), Email varchar(100), Age int );
INSERT INTO Sample_Table VALUES (1,'Bob','Smith','2295','[email protected]',24);
...

-- Create trigger
CREATE TRIGGER TriggerName ON dbo.Sample_Table FOR DELETE, INSERT, UPDATE AS
BEGIN
    -- Unpivot deleted and inserted tables
    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
    ),
    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 tables and capture 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 -- Changes
        OR (D.FieldValue IS NOT NULL AND I.FieldValue IS NULL) -- Deletions
        OR (D.FieldValue IS NULL AND I.FieldValue IS NOT NULL) -- Insertions
END

-- Execute changes
UPDATE Sample_Table SET age = age+1;
...

-- Output results
SELECT *, SQL_VARIANT_PROPERTY(FieldValueWas, 'BaseType') FieldBaseType, SQL_VARIANT_PROPERTY(FieldValueWas, 'MaxLength') FieldMaxLength from Sample_Table_Changes;

Vorteile der Alternative Lösung:

  • Vermeidet Probleme mit Bigint-Bitfeldern und Arithmetischer Überlauf
  • Anpassbares Ausgabeformat und Datentypumwandlung
  • Behandelt Szenarien mit sich ändernden natürlichen Primärschlüsseln durch Verwendung einer mit GUIDs gefüllten Spalte als eindeutige Kennung

Das obige ist der detaillierte Inhalt vonWie können geänderte Felder in SQL Server-UPDATE-Triggern mithilfe von XML oder alternativen Methoden effizient erfasst werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn