![]() |
Datenbank: MySQL • Version: 5 • Zugriff über: UniDac
Query wird nicht vom Programm ausgeführt
Hallo Zusammen,
ich bin gerade etwas verwirrt, weil ich das Verhalten meines Programms nicht nachvollziehen kann. Ich hoffe, dass Ihr mir sagen könnt, was da schief geht. Ich baue in einer Procedure eine Query zusammen, die ich dann ausführe.
Delphi-Quellcode:
Das hat auch wunderbar geklappt, bis ich drei Bedingungen hinzugefügt habe.
Query.SQL.Clear;
Query.SQL.Add('select * from prozess_position '+ ' where status<>100 and (Eckpunkt_ID='+Link[0]); //Link ist ein Array for J:=1 to Length(Link) -1 do begin //Für jede Abhängigkeit die Where Bedingung WhereQuery:=WhereQuery+' or Eckpunkt_ID='+Link[J] ; end; WhereQuery:=WhereQuery+')'; Query.SQL.Add(WhereQuery); Query.Open;
Delphi-Quellcode:
and Positionen_ID='+Rows1[1,I] and rueckm=1 and relevant=1
Das Ganze sieht dann so aus:
Delphi-Quellcode:
Das Problem ist, dass mein Programm einfach garnichts mehr macht - keine Fehlermeldung, keine Reaktion und die Uhr bleibt stehen.
Query.SQL.Clear;
Query.SQL.Add('select * from prozess_position '+ ' where status<>100 and (Eckpunkt_ID='+Link[0]); for J:=1 to Length(Link) -1 do begin //Für jede Abhängigkeit die Where Bedingung WhereQuery:=WhereQuery+' or Eckpunkt_ID='+Link[J] ; end; WhereQuery:=WhereQuery+') and Positionen_ID='+Rows1[1,I]+ ' and rueckm=1 and relevant=1'; Query.SQL.Add(WhereQuery); Query.Open; Wenn ich dann den SQL-Text bei
Delphi-Quellcode:
abfange und die Anweisung auf dem MySQL-Server direkt ausführe, bekomme ich das Ergebnis in 0,001 Sek.
Query.open;
Delphi-Quellcode:
Hat irgendjemand eine Idee, warum mein Programm mit dem SQL-Statement nicht klarkommt, obwohl der MySQL-Server so gar keine Probleme damit hat?
select * from prozess_position where status<>100
and Positionen_ID=313 and rueckm=1 and relevant=1 and (Eckpunkt_ID=8 or Eckpunkt_ID=9 or Eckpunkt_ID=12) Viele Dank Patrick |
AW: Query wird nicht vom Programm ausgeführt
Hast Du Dir das SQL einmal ausgeben lassen? Vielleicht steht da ja etwas anderes drin, als Du erwartest.
|
AW: Query wird nicht vom Programm ausgeführt
Du hast in deinem Code auch <>100 und in dem direkten Beispiel =100. Liegt es vllt. daran.
Du könntest auch diese Geschichte mit der WhereQuery-Variablen weglassen und einfach auch in der Schleife nur Query.SQL.Add benutzen... |
AW: Query wird nicht vom Programm ausgeführt
Hallo Zusammen,
@DeddyH Ja, ich habe mir das SQL-Statement ausgeben lassen, indem ich einen Haltepunkt bei "Query.Open;" gesetzt habe und das SQL-Statement abgefragt habe. Wenn ich dieses kopiere und auf dem MySQL-Server ausführe, dann bekomme ich das Ergebnis in 0,001sek. @Jumpy Ich arbeite gerade mit zwei Rechnern - der, auf dem ich programmiere hat kein Internet. Ich habe nur einen Schreibfehler beim erstellen des Themas gamacht, denn es muss <>100 heißen. Da ich das Statement aus der Query kopiert habe, ist dieser Fehler nicht vorhanden und somit auch leider nicht die Ursache... Komisch ist, dass er sich nur verschluckt, wenn ich diese 3 Bedingungen hinzufüge. Wenn ich sie wieder entferne, dann läuft es blitzschnell. An unterschiedliche Positionen im String zu setzen hat auch keinen Erfolg gebracht... Ich weiß gerade nicht so richtig weiter, weil ich dasnicht nachvollziehen kann... Gruß Patrick |
AW: Query wird nicht vom Programm ausgeführt
Was passiert denn, wenn Du einen Breakpoint auf das '.open' setzt und dann beim Debuggen diese eine Zeile ausführst?
|
AW: Query wird nicht vom Programm ausgeführt
Genau das habe ich ja gemacht, um das Query-Statement auszulesen. Mein Programm hängt sich auf. Ich habe keine Ahnung warum. Ich werde nachher mal gucken, ob es an allen 3 Bedingungen liegt, oder ob ich vielleicht die eine Bedingung herausfinde an der es liegt.
Komisch ist nur, dass der MySQL Server mit der Anweisung kein Problem hat, wenn ich einen Breakpoint auf open lege, das Statement herauskopiere und auf dem MySQL-Server direkt ausführe. Kann das an den Komponenten liegen? Ich dachte nur, das die UniDac gut sind... Und bis jetzt hatte ich auch noch keine Probleme mit Ihnen... Danke für die Unterstützung Patrick Ich habe es mal eben geprüft: Das Problem passiert durch die Bedingung " and Rueckm=1". Aber wie gesagt, direkt auf dem Server habe ich keine Probleme... |
AW: Query wird nicht vom Programm ausgeführt
Wieviele Datensätze kommen denn zurück 5,50,500 oder ???
Gruß K-H |
AW: Query wird nicht vom Programm ausgeführt
In dieser Abfrage geht es darum, dass wenn ein Datensatz zurückkommt, dass dann die nachfolgende Procedure übersprungen wird. Große Datenmengen sind also nicht das Problem. In dem aktuellen Beispiel wird auch kein Datensatz zurückgeliefert, so wie es auch sein muss...
|
AW: Query wird nicht vom Programm ausgeführt
Bei den UniDAC sollte es einen DBMonitor geben. Damit kann man sehen welchen Befehl der SQL-Server wirklich empfangen hat, also nach dem die Anfrage durch die Komponenten bearbeitet wurde.
Die Query die Du da eingestellt hast, passt an einigen Stellen nicht zu Deinem Quellcode. |
AW: Query wird nicht vom Programm ausgeführt
Vielleicht liegt das auch den ganzen ORs, die du benutzt. Zumindest bremst man damit die Abfrage auf dem Server aus. Versuch doch mal UNION:
Code:
probier es doch damit mal aus, vielleicht klappt das ja besser...
(select * from prozess_position where status<>100
and Positionen_ID=313 and rueckm=1 and relevant=1 and Eckpunkt_ID=8) union (select * from prozess_position where status<>100 and Positionen_ID=313 and rueckm=1 and relevant=1 and Eckpunkt_ID=9) union (select * from prozess_position where status<>100 and Positionen_ID=313 and rueckm=1 and relevant=1 and Eckpunkt_ID=12) Stephan |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:22 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