Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi [mySQL]: Fehler in der Abfrage, aber wo? (https://www.delphipraxis.net/21883-%5Bmysql%5D-fehler-der-abfrage-aber-wo.html)

yankee 9. Mai 2004 14:19


[mySQL]: Fehler in der Abfrage, aber wo?
 
Ich habe folgende SQL-Anweisung:
Delphi-Quellcode:
    ZQuery2.SQL.Text :='DELETE FROM `bestellungen` WHERE Titel LIKE :ITitel, Anzahl LIKE :IAnzahl, Lehrer LIKE :ILehrer, VERLAG LIKE :IVerlag, Bestellnr LIKE :IBestellnr, Preis LIKE :IPreis LIMIT 1';
    ZQuery2.ParamByName('ITitel').Value :=ZQuery2.fieldbyname('Titel').AsString;
    ZQuery2.ParamByName('IAnzahl').Value :=ZQuery2.fieldbyname('Anzahl').AsInteger;
    ZQuery2.ParamByName('ILehrer').Value :=ZQuery2.fieldbyname('Lehrer').AsString;
    ZQuery2.ParamByName('IVerlag').Value :=ZQuery2.fieldbyname('Verlag').AsString;
    ZQuery2.ParamByName('IBestellnr').Value :=ZQuery2.fieldbyname('Bestellnr').AsString;
    ZQuery2.ParamByName('IPreis').Value :=ZQuery2.fieldbyname('Preis').AsFloat;
    ZQuery2.ExecSQL;
In der zweiten Zeile tritt eine exception auf. Der versucht mir doch tasächlich zu erzählen die Spalte Titel würde es nicht geben. welch ein Blödsinn!!!
Wo ist also der Fehler?

ibp 9. Mai 2004 14:49

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
hi, versuchs mal mit:
Delphi-Quellcode:
ZQuery2.params.ParamByName('ITitel')......

yankee 9. Mai 2004 15:05

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Fehlermeldung bleibt die gleiche...

kiar 9. Mai 2004 15:11

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
hallo yankee

unübersichtlich

versuche mal die anzahl nicht mit like sonder mit = auszuwerten

Robert_G 9. Mai 2004 15:21

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Du willst Werte von ZQuery2 verwenden um Das DELETE-Statement in der selben Query zu filtern????
Wie soll denn das gehen?
Du musst dir die Werte in Variablen zwischespeichern, oder für das Löschen eine neue Query erzeugen.

Ein wenig Code-Formatierung würde dem spaghetti-Klumpen im ersten Post auch nicht Schaden. ;)
Damit hättest du nämlich gesehen, dass du per Copy'nPaste auch "LIMIT 1" mitkopiert hast. Das macht hier doch keinen Sinn, du willst doch nicht nur einen DS löschen sondern alle, die deinem Filter entsprechen.
Delphi-Quellcode:
With Query Do
Begin
  SQL.Text :=
    'DELETE FROM Bestellungen' + #10 +
    'WHERE Titel    = :ITitel And' + #10 +
    '      Anzahl   = :IAnzahl And' + #10 +
    '      Lehrer   = :ILehrer And' + #10 +
    '      VERLAG   = :IVerlag And' + #10 +
    '      Bestellnr = :IBestellnr And' + #10 +
    '      Preis    = :IPreis';
  // Werte an Query Parameter übergeben...
  With Parameters Do
  Begin
    ParamByName('ITitel').AsString    := IrgendeineVariable;
    ParamByName('IAnzahl').AsInteger  := IrgendeineVariable;
    ParamByName('ILehrer').AsString   := IrgendeineVariable;
    ParamByName('IVerlag').AsString   := IrgendeineVariable;
    ParamByName('IBestellnr').AsString := IrgendeineVariable;
    ParamByName('IPreis').AsFloat     := IrgendeineVariable;
  End;
  ExecSQL;
End;
p.s.:
man löscht generell nur über einen exakten Prim. Key (um menschl. Fehler zu minimieren).

ibp 9. Mai 2004 15:23

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
versuche es mal damit...

Delphi-Quellcode:
ZQuery2.SQL.Text:='{erste Abfrage}';
ZQuery2.open;
ZQuery2.first;
var_titel:=ZQuery2.fieldbyname('Titel').AsString;
//...
//...
ZQuery2.sql.clear;

ZQuery2.SQL.Text :='DELETE FROM `bestellungen` WHERE Titel LIKE :ITitel, Anzahl LIKE :IAnzahl, Lehrer LIKE :ILehrer, VERLAG LIKE :IVerlag, Bestellnr LIKE :IBestellnr, Preis LIKE :IPreis LIMIT 1';
ZQuery2.par5ams.ParamByName('ITitel').Value :=var_titel;
//...
ZQuery2.ExecSQL;

yankee 9. Mai 2004 15:45

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Ich will den Datensatz, den der User im DBGrid auswählt löschen.
Muss doch eigentlich einfacher gehen? Warum geht das nicht mit ein und dem selben Query?

Sharky 9. Mai 2004 16:32

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Hai yankee,
warum alles so kompliziert ;-)

Du hast doch sicher ein ID-Feld in deiner Tabelle?!?

Also einfach:

Delphi-Quellcode:
var
  aktive_id : Integer;
begin
  with ZQuery2 do
  begin
    aktive_id := FieldByName ('id').AsInteger;
    Close;
    SQL.Text := 'DELETE FROM bestellungen WHERE id=:id';
    ParamByName ('id').AsInteger := aktive_id;
    ExecSQL;
  end;
end;
Wobei Du jetzt noch das DBGrid neu füllen müsstest wenn ZQuery2 das DataSet für dein DBGrid ist. Aber wenn es dies ist mache doch einfach ein "ordinäres" ZQuery2.Delete.

yankee 9. Mai 2004 16:33

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Also ich habe meinen Code abgeändert:
Delphi-Quellcode:
var ITitel, ILehrer, IVerlag, IBestellnr:string;
    IPreis: Double;
    IAnzahl: Integer;
begin
    ZQuery2.Active :=False; //Das
    ZQuery2.Close;        //und das habe ich mal wegegelassen
    ITitel :=ZQuery2.fieldbyname('Titel').AsString; //Hier ist der Fehler
    IAnzahl :=ZQuery2.fieldbyname('Anzahl').AsInteger;
    ILehrer :=ZQuery2.fieldbyname('Lehrer').AsString;
    IVerlag :=ZQuery2.fieldbyname('Verlag').AsString;
    IBestellnr :=ZQuery2.fieldbyname('Bestellnr').AsString;
    IPreis :=ZQuery2.fieldbyname('Preis').AsFloat;

    ZQuery2.SQL.Text :='DELETE FROM `bestellungen` WHERE `Titel` = :ITitel AND `Anzahl` =:IAnzahl AND `Lehrer` =:ILehrer AND `Verlag` =:IVerlag AND `Bestellnr` =:IBestellnr AND CONCAT( `Preis` ) =:IPreis LIMIT 1';
    ZQuery2.ParamByName('ITitel').Value :=ITitel;
    ZQuery2.ParamByName('IAnzahl').Value :=IAnzahl;
    ZQuery2.ParamByName('ILehrer').Value :=ILehrer;
    ZQuery2.ParamByName('IVerlag').Value :=IVerlag;
    ZQuery2.ParamByName('IBestellnr').Value :=IBestellnr;
    ZQuery2.ParamByName('IPreis').Value :=IPreis;
    ZQuery2.Open;
    ZQuery2.Active :=True;
Fehlermeldung: ZQuery2: Field 'Titel' not found
Also es hat sich nichts verändert!
Und nochwas: Die Exception tritt wieder gaanz oben auf (siehe kommentierung)
Und das gibt es noch zwei Teile. Wenn ich die weglasse, löscht er den entsprechenden Eintrag, aber es gibt eine Adress Violation...

Sharky 9. Mai 2004 16:38

Re: [mySQL]: Fehler in der Abfrage, aber wo?
 
Zitat:

Zitat von yankee
Also ich habe meinen Code abgeändert:
Delphi-Quellcode:
var ITitel, ILehrer, IVerlag, IBestellnr:string;
    IPreis: Double;
    IAnzahl: Integer;
begin
    ZQuery2.Active :=False; //Das
    ZQuery2.Close;        //und das habe ich mal wegegelassen
    ITitel :=ZQuery2.fieldbyname('Titel').AsString; //Hier ist der Fehler
....

Hai yankee,

Du kanst nacht dem schließen eines TDataSet nicht mehr auf die Daten zugreifen.
Das heisst: Nach deinem ZQuery2.Close kannst Du keine Daten mehr von ZQuery2 bekommen!!!


Alle Zeitangaben in WEZ +1. Es ist jetzt 18:01 Uhr.
Seite 1 von 3  1 23      

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