AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi AdoCommand: Delete-Statement mit Parametern
Thema durchsuchen
Ansicht
Themen-Optionen

AdoCommand: Delete-Statement mit Parametern

Ein Thema von HeikoAdams · begonnen am 10. Jan 2008 · letzter Beitrag vom 10. Jan 2008
Antwort Antwort
Benutzerbild von HeikoAdams
HeikoAdams

Registriert seit: 12. Jul 2004
Ort: Oberfranken
661 Beiträge
 
FreePascal / Lazarus
 
#1

AdoCommand: Delete-Statement mit Parametern

  Alt 10. Jan 2008, 14:05
Datenbank: SQL Server • Version: 2000 • Zugriff über: ADO
Hallo,
ich versuche, über folgendes SQL-Statement Daten aus einer Datenbank zu löschen
DELETE FROM KundenDubletten WHERE column12 = :pWert Der Delphi-Code, um den Parameter zu füllen und das Statement auszuführen ist folgender:
Delphi-Quellcode:
with DelCmd do
begin
  CommandText := 'DELETE FROM KundenDubletten WHERE column12 = :pWert';

  with Parameters do
  begin
    Clear;
    CreateParameter('pWert', ftString, pdInput, MAX_PATH, QuotedStr(Codes.Strings[Count]));
    ParamValues['pWert'] := Trim(QuotedStr(Codes.Strings[Count]));
  end;

  try
    Execute;
  except
    on e:Exception do ShowMessage(e.Message);
  end;
end;
Allerdings scheint es, als ob das TAdoCommand bei Delete Anweisungen keine Parameter unterstützt, da keine Daten gelöscht werden oder mache ich einfach nur etwas falsch?
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.171 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: AdoCommand: Delete-Statement mit Parametern

  Alt 10. Jan 2008, 14:08
[gelöscht da durch ergänzten Posttext unnötig geworde]
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#3

Re: AdoCommand: Delete-Statement mit Parametern

  Alt 10. Jan 2008, 16:50
Wenn du String-Parameter verwendet, braucht man (darf man) die Daten nicht mit QuotedStr() verpacken !
Man beachte auch das verbesserte Exception-Handling.
Delphi-Quellcode:
with DelCmd do
begin
  CommandText := 'DELETE FROM KundenDubletten WHERE column12 = :pWert';
  with Parameters do
  begin
    ParamValues['pWert'] := Trim(Codes.Strings[Count]);
  end;

  try
    Execute;
  except
    on e:Exception do
    begin
       e.Message := 'Fehler beim Löschen von Dubletten'#13#10 + CommandText + #13#10+
          e.Message;
       raise;
    end;
  end;
end;
Andreas
  Mit Zitat antworten Zitat
Antwort Antwort


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 15:23 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz