![]() |
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:
Diese möchte ich nun in Delphi wie folgt verarbeiten:
'SELECT Month(created), count(*) FROM tabelle where year(created)='Jahr' GROUP BY Month(created);';
Delphi-Quellcode:
Wenn ich dieses Statement über phpMyAdmin absetzte funktioniert das Ganze auch wunderbar. Nur mit dem obigen Delphi-Code bekomme
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; 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 |
Re: SQL-Statement - Was mach ich falsch?
Das liegt nicht am Gleichheitszeichen, sondern an den Hochkommata. Kannst Du die Abfrage parametrisieren?
|
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? |
Re: SQL-Statement - Was mach ich falsch?
QuotedStr wäre mein nächster Vorschlag gewesen ;)
|
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.
|
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 |
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 |
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; |
Re: SQL-Statement - Was mach ich falsch?
Hallo Steffim,
Zitat:
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