sql >> Databáze >  >> RDS >> Mysql

delphi dxExpress MySQL:neplatná hodnota LAST_INSERT_ID

ID byste měli získat jedním tahem

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;

a měli byste přemýšlet o použití parametrů, abyste zabránili vkládání 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. Jak optimalizovat mysql dotaz získávání kategorií a podkategorií

  2. Jak nainstalovat sqlcmd &bcp na Ubuntu

  3. Je vložení/aktualizace spojení na MySQL atomická operace?

  4. Při pokusu o spuštění pgAdmin4 došlo k chybě