Einzelnen Beitrag anzeigen

Benutzerbild von Memo
Memo

Registriert seit: 19. Aug 2003
509 Beiträge
 
Delphi 7 Enterprise
 
#8

Re: last_insert_id() funzt nicht..

  Alt 3. Mai 2007, 16:03
Du hast zwar geschrieben, das Du mit Zeos auf die DB zugreifst, aber kann es sein, das Du Deine Statements mit einem MySQL-Admintool abschickst?

Last_insert_id funktioniert soweit ich mich erinnere nur innerhalb einer Session. Wenn Du also ein Insert absetzt, gugst ob es geklappt hat und dann erst die Id abfragst (in einer neuen Session)bekommst Du Null.
In einer Mehrbenutzerumgebung wird damit gewährleistet, dass man die Id seines eigenen zuletzt eingefügten Satzes bekommt und nicht die von einem anderen Users erhält.
Einfach hier eingetippt, also ungestestet:
Delphi-Quellcode:
Query1.Sql.Text := 'INSERT INTO hwpool.test (test) VALUES '+QuotedStr('bla') ';
Query1.Execute; //oder wie es bei Zeos heisst
Query1.Sql.Text :=
'Select Last_Insert_Id() from test';
Query1.Open;
ShowMessage(Query.Fields[0].AsString);
Wenn du nur den grössten Wert brauchst nimm: Max(ID)
  Mit Zitat antworten Zitat