AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL Insert Into Problem

SQL Insert Into Problem

Ein Thema von renekr · begonnen am 13. Feb 2006 · letzter Beitrag vom 15. Feb 2006
 
jensw_2000
(Gast)

n/a Beiträge
 
#13

Re: SQL Insert Into Problem

  Alt 15. Feb 2006, 08:44
Du kannst das ganze auch umkompliziert über eine Stored Procedure machen.
So kannst du auch gleich Daten-Updates mit realisieren.
Zudem hast du den Vorteil, das die SP deine Anwendung von der DB entkoppelt. Falls sich später Feldnamen ändern oder die Daten woanders gespeichert werden sollen, dann eine musst du nur die SP anpassen.

Hier ein kleines Beispiel:


auf dem SQL-Server einmalig eine SP erzeugen
SQL-Code:
CREATE PROCEDURE SET_Table1_Data
  @ID INT =NULL
  @NVARCHAR_VALUE NVARCHAR(255) = NULL,
AS
BEGIN
  -- Parameter prüfen
  
  -- Daten aktualisieren, falls ID nicht NULL ist und existiert
  UPDATE Table1 SET Ein_VARCHAR_Feld = @NVARCHAR_VALUE
  WHERE ID = @ID AND ID IS NOT NULL

  IF @@ROWCOUNT = 0 -- (also kein Datensatz aktualisiert wurde (RowsAffected =0) )
  BEGIN
    INSERT INTO Table1 (
                         Ein_NVARCHAR_Feld
                       )
              VALUES (
                         @NVARCHAR_VALUE
                       )
  END

END


In Delphi würde ich die SP so benutzen:

Delphi-Quellcode:
function SaveData:Boolean;
  var SP:TAdoStoredPoc;
begin
  
  Result:=False;
  SP:=TAdoStoredProc.create(nil);
  try
    SP.Connection:=Datamodule1.AdoConn; // hier gehören noch ein paar Prüfungen hin
    SP.Procedurename='SET_Table1_Data'; // z.B. ist AdoConn.Connected=true ?
    SP.Parameters.refresh; //
    SP.Parameters[2].value:=Eine_ID_oder_NULL;
    SP.Parameters[3].value:=Ein_String_der_in_NVARCHAR_Feld_geschrieben_werden_soll;
    SP.ExecProc;
    Result:=true;
  finally
    FreeAndNil(SP);
  end;
end;


Schöne Grüße,
Jens
  Mit Zitat antworten Zitat
 

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

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 04: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