Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi SQL-Statement - Was mach ich falsch? (https://www.delphipraxis.net/104620-sql-statement-mach-ich-falsch.html)

Stern 7. Dez 2007 16:50

Datenbank: MySQL • Version: 5 • Zugriff über: Zeos

SQL-Statement - Was mach ich falsch?
 
Hallo zusammen,

ich bekomme aus meiner PHP-Datei folgendes SQL-Statement zur Weiterverarbeiotung in Delphi:

SQL-Code:
'SELECT Month(created), count(*) FROM tabelle where year(created)='Jahr' GROUP BY Month(created);';
Diese möchte ich nun in Delphi wie folgt verarbeiten:
Delphi-Quellcode:
qrMain.SQL.Clear;
        qrMain.SQL.Text:= 'SELECT Month(created), count(*) FROM tabelle where year(created)='Jahr' GROUP BY Month(created);';
        qrMain.Active:= True;
        qrMain.open;
Wenn ich dieses Statement über phpMyAdmin absetzte funktioniert das Ganze auch wunderbar. Nur mit dem obigen Delphi-Code bekomme
ich einen Fehler: Operator oder Semikolon fehlen... Dies ist bei allen Statements, die ein "=" enthalten der Fall. Irgendwie bekomme
ich es jedenfalls nicht hin das Statement korrekt anzugeben. Was muss ich den daran ändern???
Ich bin mir sicher, dass irgendwo noch ein ' hin muss, aber ich komm nicht drauf, wie das Statement korrekt aussehen muss.

Kann mir da jemand behilflich sein?


Liebe Grüße
Steffi

DeddyH 7. Dez 2007 16:51

Re: SQL-Statement - Was mach ich falsch?
 
Das liegt nicht am Gleichheitszeichen, sondern an den Hochkommata. Kannst Du die Abfrage parametrisieren?

Stern 7. Dez 2007 16:59

Re: SQL-Statement - Was mach ich falsch?
 
hmmm... das Probloem ist, dass ich ungefähr 25 solcher Queries bekomme. Parametrisieren könnte ich das ganze schon.
Wäre alles inallem vielleicht etwas umständlich. Aber gibt es da nicht noch etwas mit quotedStr(); oder etwas in der Richtung?

Liebe Grüße
Steffi

PS: Ich sehe gerade, dass in meinem phpMyAdmin die Anfrage auch ohne Hochkommata durchgeht... :gruebel: Kann ich im Statement diese vielleicht
einfach weglassen?

DeddyH 7. Dez 2007 17:01

Re: SQL-Statement - Was mach ich falsch?
 
QuotedStr wäre mein nächster Vorschlag gewesen ;)

mkinzler 7. Dez 2007 17:03

Re: SQL-Statement - Was mach ich falsch?
 
QuotedStr() würde auch gehen, aber Parameter sind wohl die bessere Lösung. U.U. kannst du so auch die Anzahl der verschiedenen Abfragen minimieren.

Stern 7. Dez 2007 17:21

Re: SQL-Statement - Was mach ich falsch?
 
Ok, das sehe ich ein. wäre wohl besser das ganze durch parameter zu lösen. Muss ich wohl nochmal an die PHP-Datei ran...

Vielen Dank und liebe Grüße
Steffi

Stern 7. Dez 2007 17:36

Re: SQL-Statement - Was mach ich falsch?
 
Oh, ich vergaß :oops: Muss ich bei der parametrisierten Abfrage etwas besonderes beachten? Kleines Beispiel?

Vielen Dank und liebe Grüße
Steffi

mkinzler 7. Dez 2007 17:41

Re: SQL-Statement - Was mach ich falsch?
 
Delphi-Quellcode:
qrMain.SQL.Text:= 'SELECT Month(created), count(*) FROM tabelle where year(created)=:jahr GROUP BY Month(created);';
...
qrMain.ParamByName('jahr').asString := Jahr;

marabu 7. Dez 2007 17:58

Re: SQL-Statement - Was mach ich falsch?
 
Hallo Steffim,

Zitat:

Zitat von Stern
... Kann ich im Statement diese vielleicht einfach weglassen? ...

in dem von dir gezeigten Beispiel schon - nur Zeichenkettenwerte müssen in Quotes eingeschlossen werden.

Grüße vom marabu


Alle Zeitangaben in WEZ +1. Es ist jetzt 22:02 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 by Thomas Breitkreuz