AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi query rückgabe wert
Thema durchsuchen
Ansicht
Themen-Optionen

query rückgabe wert

Ein Thema von Delphi-Phil · begonnen am 5. Jan 2009 · letzter Beitrag vom 5. Jan 2009
Antwort Antwort
Delphi-Phil

Registriert seit: 22. Jun 2007
410 Beiträge
 
#1

query rückgabe wert

  Alt 5. Jan 2009, 13:32
Datenbank: mysql • Zugriff über: ado
Hallo Zusammen und ein frohes Neus Jahr,

ich habe eine ganz normale SQL Abfrage mit einer Query. Jetzt möchte ich prüfen ob die Query ein Ergebnis liefert oder nicht und dann soll eine if then anweisung kommen!

Wie prüfe ich ob ein Ergebnis aus der Query kommt??
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.625 Beiträge
 
Delphi 12 Athens
 
#2

Re: query rückgabe wert

  Alt 5. Jan 2009, 13:40
Entweder RecordCount auf > 0 prüfen oder eben schauen, ob EOF erreicht ist.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
Delphi-Phil

Registriert seit: 22. Jun 2007
410 Beiträge
 
#3

Re: query rückgabe wert

  Alt 5. Jan 2009, 13:54
Aber bei Eof habe ich doch noch keinen Wert oder??
  Mit Zitat antworten Zitat
Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#4

Re: query rückgabe wert

  Alt 5. Jan 2009, 13:58
Zitat von Delphi-Phil:
Aber bei Eof habe ich doch noch keinen Wert oder??
Wenn die Abfrage nichts liefert, steht der Zeiger sofort auf EOF.

Gruß,
Jens
Jens
  Mit Zitat antworten Zitat
Delphi-Phil

Registriert seit: 22. Jun 2007
410 Beiträge
 
#5

Re: query rückgabe wert

  Alt 5. Jan 2009, 14:59
irgendwie muss was falsch sein...

wie kommt meine fehlermeldung nicht???


Delphi-Quellcode:
//Fach hinzufügen
procedure TStammdaten.JvXPButton1Click(Sender: TObject);
var
Qry : TADOQuery;
QryFachVorhanden : TADOQuery;
SID : Integer;
FID : Integer;
KID : Integer;
begin

SID := QrySchueler.fieldbyname('ID').AsInteger;
FID := self.TblFaecher.fieldbyname('ID').AsInteger;
KID := Hauptform.QrySchueler.FieldByName('idKlasse').AsInteger;


//Abfragen ob Fach schon vorhanden
QryFachVorhanden := TADOQuery.Create(self);
QryFachVorhanden.Connection := HauptForm.ADOConnection1;
QryFachVorhanden.SQL.Text := 'select *from schueler_faecher where id_Schueler = :SID and id_Fach = :FID and id_Klasse = :KID';
QryFachVorhanden.Parameters.ParamByName('SID').Value := SID;
QryFachVorhanden.Parameters.ParamByName('FID').Value := FID;
QryFachVorhanden.Parameters.ParamByName('KID').Value := KID;
QryFachVorhanden.ExecSQL;
if QryFachVorhanden.Eof = true then

begin
Qry := TADOQuery.Create(self);
Qry.Connection := HauptForm.ADOConnection1;
Qry.SQL.Text := 'insert into schueler_faecher (id_Schueler,id_Fach,id_Klasse) values (:SID, :FID, :KID)';
Qry.Parameters.ParamByName('SID').Value := SID;
Qry.Parameters.ParamByName('FID').Value := FID;
Qry.Parameters.ParamByName('KID').Value := KID;
Qry.ExecSQL;
QryZugeFaecher.Close;
QryZugeFaecher.Open;
Qry.Free;
end
else
MessageDlg('Das Fach wurde schon zugeordnet.', mtError, [mbOK], 0);
end;
  Mit Zitat antworten Zitat
nahpets
(Gast)

n/a Beiträge
 
#6

Re: query rückgabe wert

  Alt 5. Jan 2009, 15:06
Hallo,

muss das nicht stattQryFachVorhanden.ExecSQL; QryFachVorhanden.Open; heißen?
Du möchtest doch wissen, ob es etwas schon gibt oder eben nicht.
Versuch es doch mal mit:
Delphi-Quellcode:
QryFachVorhanden.SQL.Text := 'select Count(*) As Anzahl from schueler_faecher where id_Schueler = :SID and id_Fach = :FID and id_Klasse = :KID';
QryFachVorhanden.Open;
If QryFachVorhanden.FieldByName('Anzahl').AsInteger = 0 then
  // und hier dann weiter mit dem Insert...
  Mit Zitat antworten Zitat
Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#7

Re: query rückgabe wert

  Alt 5. Jan 2009, 15:16
Delphi-Quellcode:
QryFachVorhanden.SQL.Text := 'select *from schueler_faecher where id_Schueler = :SID and id_Fach = :FID and id_Klasse = :KID';
// ^-- hier fehlt ne leerstelle
QryFachVorhanden.Parameters.ParamByName('SID').Value := SID;
QryFachVorhanden.Parameters.ParamByName('FID').Value := FID;
QryFachVorhanden.Parameters.ParamByName('KID').Value := KID;
//QryFachVorhanden.ExecSQL;
QryFachVorhanden.Open; //ExcecSQL nimmt man nur, wenn man keine Rückgabe erwartet (z.B. beim Insert).
...
Jens
  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 15:38 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