Zum Inhalt springen

SQL: Autowert ID nach einem Insert rauskriegen


Empfohlene Beiträge

Geschrieben

Hallo zusammen,

ich speichere in eine Tabelle (mittels INSERT) einen Datensatz. Dieser bekommt als PrimeryKey einen Autowert. Nun muss ich unmittelbar nach dem abspeichern mit diesem PrimeryKey weiterarbeiten (als Fremdschlüssel in anderen Tabellen).

Wie kriege ich diesen PrimeryKey raus?

Gibt es sowas wie Rückgabetyp bei SQL?

Danke

Ciao

Antibiotik

P.S. Ich arbeite mit MS SQL Server 2005

Geschrieben
Wenn ich den PrimaryKey später brauche dann mach ich nach dem einfügen

so etwas


Select max(ID) from tabelle;

Hoffentlich nur in einer Transaktion oder Single Thread Anwendung. :rolleyes:;)

Geschrieben
Hi,

das geht AFAIK ungefähr mit


SELECT @@Identity AS NewID

FROM Tabelle

Nope. Das "FROM Tabelle" bringt Dir gar nichts, weil der MSSQL an dieser Stelle immer die letzte erzeugte ID der Verbindung zurück gibt.

Der Rest würde aber passen.

Gruß,

der Onkel

Geschrieben

frag nach den eingefügten Daten

INSERT INTO tb_abc (val1,val2,val3,val4,...,valn) VALUES ('val1','val2','val3'...)
und dann
SELECT id FROM tb_abc WHERE val1 = 'val1' AND val2 = 'val2' ... AND valn = 'valn'

Geschrieben

In manchen Datenbanken funktioniert auch

SELECT LAST_INSERT_ID FROM [Tabellenname]

Eine leider oft und gern benutzte Methode, die allerdings sehr unsauber bis gefährlich ist wäre:

SELECT MAX([Primärschlüssel]) FROM [TabellenName]

allerdings kann das schwer in die Hose gehen, wenn Deine DB Engine AutoIncrement-Keys auch in "Lücken" vergibt. Der Key, den Du hier zurückbekämst ist eben nur der numerisch größte und nicht zwangsläufig der zuletzt vergeben; IMHO gehört derjenige, der sowas macht geschlagen. ;)

Erstelle ein Benutzerkonto oder melde Dich an, um zu kommentieren

Du musst ein Benutzerkonto haben, um einen Kommentar verfassen zu können

Benutzerkonto erstellen

Neues Benutzerkonto für unsere Community erstellen. Es ist einfach!

Neues Benutzerkonto erstellen

Anmelden

Du hast bereits ein Benutzerkonto? Melde Dich hier an.

Jetzt anmelden

Fachinformatiker.de, 2024 by SE Internet Services

fidelogo_small.png

Schicke uns eine Nachricht!

Fachinformatiker.de ist die größte IT-Community
rund um Ausbildung, Job, Weiterbildung für IT-Fachkräfte.

Fachinformatiker.de App

Download on the App Store
Get it on Google Play

Kontakt

Hier werben?
Oder sende eine E-Mail an

Social media u. feeds

Jobboard für Fachinformatiker und IT-Fachkräfte

×
×
  • Neu erstellen...