Antibiotik Geschrieben 31. März 2006 Geschrieben 31. März 2006 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
DevHB Geschrieben 31. März 2006 Geschrieben 31. März 2006 Hi, das geht AFAIK ungefähr mit SELECT @@Identity AS NewID FROM Tabelle
Pinhead Geschrieben 31. März 2006 Geschrieben 31. März 2006 Wenn ich den PrimaryKey später brauche dann mach ich nach dem einfügen so etwas Select max(ID) from tabelle;
Jaraz Geschrieben 31. März 2006 Geschrieben 31. März 2006 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.
HolzOnkel Geschrieben 8. April 2006 Geschrieben 8. April 2006 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
SNOWMAN Geschrieben 10. April 2006 Geschrieben 10. April 2006 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'
Code Poet Geschrieben 10. April 2006 Geschrieben 10. April 2006 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.
Empfohlene Beiträge
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 erstellenAnmelden
Du hast bereits ein Benutzerkonto? Melde Dich hier an.
Jetzt anmelden