AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Update & Insert getrennt manuell ausführen oder eine Stored Procedure ?
Thema durchsuchen
Ansicht
Themen-Optionen

Update & Insert getrennt manuell ausführen oder eine Stored Procedure ?

Ein Thema von RWarnecke · begonnen am 15. Feb 2013 · letzter Beitrag vom 15. Feb 2013
 
Benutzerbild von sx2008
sx2008

Registriert seit: 15. Feb 2008
Ort: Baden-Württemberg
2.332 Beiträge
 
Delphi 2007 Professional
 
#4

AW: Update & Insert getrennt manuell ausführen oder eine Stored Procedure ?

  Alt 15. Feb 2013, 12:24
Wenn es nicht auf maximale Geschwindigkeit ankommt, dann kann man deine Anforderung sehr flexibel mit Delphi-Code lösen:
Delphi-Quellcode:
query.SQL.Tet := 'SELECT * FROM Tabelle WHERE keyfeld=:keyfeld';
query.parameters.ParamValues['keyfeld'] := ...; // muss ggf. an Zugriffskomponente angepasst werden
query.Open;
if query.IsEmpty then
begin
  // neuen Datensatz einfügen
  query.Append;
  // hier alle Felder beschreiben, die nur beim INSERT befüllt werden müssen
  query['keyfeld'] := ...;
  query['Spalte7'] := ...;
end
else
begin
  // bestehenden Datensatz ändern
  query.Edit;
  // hier alle Felder beschreiben, die nur beim UPDATE geändert werden müssen
  query['AnzahlModifikationen'] := query['AnzahlModifikationen'] + 1;
end;

// hier alle Felder befüllen, die sowohl beim INSERT als auch beim UPDATE geschrieben werden
query['Feld1'] := ...;
query['Feld2'] := ...;
query.Post; // Datensatz schreiben, im Hintergrund wird ein INSERT oder UPDATE generiert und abgeschickt
  Mit Zitat antworten Zitat
 


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 11:31 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