AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi MySQL: Prüfen ob Zeile existiert
Thema durchsuchen
Ansicht
Themen-Optionen

MySQL: Prüfen ob Zeile existiert

Ein Thema von DanielF · begonnen am 22. Jan 2003 · letzter Beitrag vom 28. Jan 2003
Antwort Antwort
DanielF

Registriert seit: 18. Jan 2003
110 Beiträge
 
Delphi 7 Professional
 
#1

MySQL: Prüfen ob Zeile existiert

  Alt 22. Jan 2003, 20:10
in meinem Script kommt diese Zeile vor:

Code:
MySQLQuery1.sql.Text := 'select * from users where uid='+uid;
Wenn es jetzt keine Zeile mit der eingestellten uid gibt, kommt folgender Fehler:
"You have an error in your SQL syntax near " at line 1"
Das wär ja eigentlich nich schlimm, denn ich könnte ja mit "try-except" den Benutzer dazu zwingen eine neue uid einzugeben, aber des except wird nicht ausgeführt. Kann mir jemand helfen?
  Mit Zitat antworten Zitat
Benutzerbild von harrybo
harrybo

Registriert seit: 26. Nov 2002
Ort: Aachen
87 Beiträge
 
Delphi 6 Enterprise
 
#2
  Alt 22. Jan 2003, 20:58
Hi DanielJ,

setz doch mal einen Haltepunkt auf genau diese Zeile und schau Dir im Debugger den aktuellen Wert von "uid" an, bzw. den ganzen SQL-String. Wenn Deine SQL Anweisung einen Syntax Fehler aufweist, stimmt bereits an dieser Stelle etwas nicht, die Anweisung wird nicht ausgeführt werden, es kommt also erst gar nicht zu der Frage, ob die "uid" existiert oder nicht. Wenn ich meinen Kumpel bitte: "Kannst Du uns ma 'n Kasten Pils holen?", wär's doch schon komisch, wenn der loszieht, zurückkommt und sagt: "Pils is alle, aber ich hab Deine Frage nicht verstanden."

Falls Du nicht weiterkommst, schick bitte etwas mehr Code.

gruß, harrybo
Harry Boldt
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.252 Beiträge
 
Delphi 2006 Professional
 
#3

Re: MySQL: Prüfen ob Zeile existiert

  Alt 23. Jan 2003, 10:39
Hai,

von was für einem Typ ist denn uid ?

Zahl oder String?

Wenn es ein String ist, muss bei vielen SQL-Dialekten der Parameter in
Hochkommas stehen.

z.B.:
Code:
 SELECT * FROM adressen WHERE name = 'Sharky'
Im Quellcode müsste dann stehen:

Delphi-Quellcode:
Query1.Close;
Query1.SQL.Text := 'SELECT * FROM adressen WHERE name = '
                   + QuotedStr ('Sharky');
Query1.Open;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
stiggi

Registriert seit: 27. Jan 2003
12 Beiträge
 
#4
  Alt 28. Jan 2003, 13:57
Zitat:
"You have an error in your SQL syntax near " at line 1"
sagt ja aus, daß Dein SQL Statement nicht korrekt ist. Wenn die UID nicht vorhanden wäre, würdest Du nur keinen Datensatz zurückbekommen, aber keine Fehlermeldung.

Ich tippe auch mal auf das was Sharky gepostet hat. Oder Du hast das weiterverknüpft - wenn Du z.b. das Ergebnis dieser Abfrage gleich in eine weitere Abfrage einbindest. In diesem Fall würdest Du bei einer nicht existenden UID auch keinen Wert für die zweite Abfrage rausbekommen und somit ist in dieser die Syntax falsch.



Code:
1.SQL: SELECT name FROM Users WHERE UID = 10
-> 10 existiert nicht ..
Code:
2.SQL: SELECT * FROM Adresse WHERE name = ' + QuotedStr (Query1.FieldByName('name'))
  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 14:37 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