AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi id des soeben angelegten Datensatzes?
Thema durchsuchen
Ansicht
Themen-Optionen

id des soeben angelegten Datensatzes?

Ein Thema von SearchBot · begonnen am 21. Nov 2019 · letzter Beitrag vom 22. Nov 2019
Antwort Antwort
EmWieMichael

Registriert seit: 28. Mär 2012
103 Beiträge
 
#1

AW: id des soeben angelegten Datensatzes?

  Alt 21. Nov 2019, 16:33
Ich mach das so...

Delphi-Quellcode:
Query.SQL.Add('INSERT INTO TABELLE ... VALUES ...');
Query.SQL.Add('SELECT SCOPE_IDENTITY() AS [SCOPE_IDENTITY]');
Query.Open;
if (Query.RecordCount = 1) then
 begin
   RecID:=Query.Fields.FieldByName('SCOPE_IDENTITY').AsString;
   ...
 end;
  Mit Zitat antworten Zitat
Redeemer

Registriert seit: 19. Jan 2009
Ort: Kirchlinteln (LK Verden)
1.134 Beiträge
 
Delphi 2009 Professional
 
#2

AW: id des soeben angelegten Datensatzes?

  Alt 21. Nov 2019, 22:53
Die Lösung von EmWieMichael ist mMn die korrekte, so mache ich das auch.

Der Fehler vom TE kommt daher, dass es in der Query
Code:
SELECT max(id) FROM tabelle
keinen Spaltennamen id gibt, er aber versucht, darauf zuzugreifen. Ist aber wie gesagt auch der falsche Ansatz, denn genau dafür gibt es IDENTITY. Beachte, dass man Identitätsfelder nicht selbst schreiben kann. Kennt man von MySQL anders.
Janni
2005 PE, 2009 PA, XE2 PA
  Mit Zitat antworten Zitat
EmWieMichael

Registriert seit: 28. Mär 2012
103 Beiträge
 
#3

AW: id des soeben angelegten Datensatzes?

  Alt 22. Nov 2019, 06:40
...
Beachte, dass man Identitätsfelder nicht selbst schreiben kann. Kennt man von MySQL anders.

Doch, geht auch mit MSSQL; die DB wäre für mich sonst auch unbrauchbar:
Delphi-Quellcode:
Query.SQL.Add('SET IDENTITY_INSERT TABELLE ON');
Query.SQL.Add('INSERT INTO TABELLE ... VALUES ...');
Query.SQL.Add('SET IDENTITY_INSERT TABELLE OFF');
Query.ExecSQL;
Result:=(Query.RowsAffected = 1);
  Mit Zitat antworten Zitat
SearchBot

Registriert seit: 27. Jun 2004
Ort: N-W vom Bodensee
328 Beiträge
 
Delphi 12 Athens
 
#4

erledigt: id des soeben angelegten Datensatzes?

  Alt 22. Nov 2019, 13:16
Dankeschön an alle, die Empfehlung von EmWieMichael trifft es genau.
  Mit Zitat antworten Zitat
Antwort Antwort

 

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06:42 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz