Mysql
 sql >> Baza danych >  >> RDS >> Mysql

delphi dxExpress MySQL:nieprawidłowa wartość LAST_INSERT_ID

Powinieneś otrzymać identyfikator za jednym razem

SQLQry := TSQLQuery.Create(self);
with SQLQry do begin
  SQLConnection := SQLCon;

  SQL.Add('INSERT INTO Sample_Table ');
  SQL.Add('(mobile_number, message_body) VALUES');
  SQL.Add(format('(%s, %s);',[QuotedStr('989121011689'), QuotedStr('Text1')]));

  SQL.Add('SELECT LAST_INSERT_ID() EngineRefNo;');

  Open;
  ListBox1.items.Add(FieldByName('EngineRefNo').AsString);
  Close;
end;

SQLCon.Close;

i powinieneś pomyśleć o użyciu parametrów, aby zapobiec wstrzykiwaniu sql

SQLQry := TSQLQuery.Create(self);
with SQLQry do begin
  SQLConnection := SQLCon;

  SQL.Add('INSERT INTO Sample_Table ');
  SQL.Add('( mobile_number, message_body ) VALUES');
  SQL.Add('( :mobile_number, :message_body );');

  SQL.Add('SELECT LAST_INSERT_ID() EngineRefNo;');

  ParamByName( 'mobile_number' ).Value := '989121011689';
  ParamByName( 'message_body' ).Value := 'Text1';

  Open;
  ListBox1.items.Add(FieldByName('EngineRefNo').AsString);
  Close;
end;

SQLCon.Close;


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Hibernacja:używaj backticków dla MySQL, ale nie dla HSQL

  2. UNIKALNE OGRANICZENIE MYSQL

  3. Jak wybrać maksymalnie 3 elementy na użytkownika w MySQL?

  4. Wybierasz wszystkie kolumny, które zaczynają się od XXX, używając symbolu wieloznacznego?

  5. jak usunąć zduplikowane wiersze z tabeli w mysql