Heim > Datenbank > MySQL-Tutorial > Wie rufe ich Identitätswerte nach dem Einfügen mehrerer Datensätze in SQL Server 2005 ohne Cursor ab?

Wie rufe ich Identitätswerte nach dem Einfügen mehrerer Datensätze in SQL Server 2005 ohne Cursor ab?

Susan Sarandon
Freigeben: 2024-12-31 13:29:10
Original
386 Leute haben es durchsucht

How to Retrieve Identity Values After Inserting Multiple Records in SQL Server 2005 Without Cursors?

Mehrere Datensätze einfügen und Identitätswerte abrufen

Beim Einfügen mehrerer Datensätze in eine Tabelle mit einer Identitätsspalte kann das Abrufen der neu generierten Identitätswerte für nachfolgende Datenmanipulationen von entscheidender Bedeutung sein . In diesem Artikel wird untersucht, wie Sie dies erreichen können, ohne einen Cursor in Microsoft SQL Server 2005 zu verwenden.

Problembeschreibung

Stellen Sie sich das folgende Szenario vor: Sie haben zwei Tabellen, Tabelle A mit einer Identitätsspalte (id). und Tabelle B, die verwandte Daten enthält. Sie möchten Datensätze aus Tabelle B in Tabelle A einfügen und die entsprechenden Identitätswerte abrufen, um die NewId-Spalte in Tabelle B zu aktualisieren.

Lösung

SQL Server 2005 bietet über die OUTPUT-Klausel einen praktischen Mechanismus um generierte Identitätswerte während Einfügevorgängen abzurufen. Der folgende Code zeigt, wie diese Funktion verwendet wird:

DECLARE @output TABLE (id int)

INSERT INTO A (fname, lname)
OUTPUT INSERTED.id INTO @output
SELECT fname, lname FROM B
Nach dem Login kopieren

Diese Abfrage fügt Datensätze aus Tabelle B in Tabelle A ein und speichert die Identitätswerte in einer Tabellenvariablen namens @output. Die Tabellenvariable @output enthält eine einzelne Spalte (id) mit den neu generierten Identitätswerten, sodass Sie diese abrufen und für die weitere Verarbeitung verwenden können.

Beispiel

Betrachten Sie die Beispieltabellen und -daten in der Problembeschreibung angegeben. Nach der Ausführung des obigen Codes:

-- Insert records into Table A and retrieve identity values
DECLARE @output TABLE (id int)

INSERT INTO A (fname, lname)
OUTPUT INSERTED.id INTO @output
SELECT fname, lname FROM B

-- Display the identity values in the table variable
SELECT * FROM @output
Nach dem Login kopieren

Das Ergebnis ist eine Tabelle mit den Identitätswerten der eingefügten Zeilen:

id
-------
1
2
3
Nach dem Login kopieren

Diese Identitätswerte können dann zum Aktualisieren der NewId verwendet werden Spalte in Tabelle B entsprechend.

Das obige ist der detaillierte Inhalt vonWie rufe ich Identitätswerte nach dem Einfügen mehrerer Datensätze in SQL Server 2005 ohne Cursor ab?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage