
Zitat von
Kruemel2oo2:
...die 3 felder sind das die von der Daten bank?
tag,monat,jahr sind die Feldenamen in der Tabelle.
Zitat:
.. was macht dieses +#10
#10 ist nicht anderes als ein Zeilenumbruch. Manche Datenbanken mögen es nicht wenn alle Befehle in einer Zeile stehen.
Zitat:
Könntest das ma nen bischen erklären bitte!
Also,
Parameter in einer
SQL-Abfrage kannst Du dir wie "platzhalter" vorstellen.
SELECT * FROM tabelle WHERE name = :param1
param1 ist jetzt mein Parameter (Platzhalter). Diesem muss ich jetzt noch einen Wert zuweisen. Das passiert mit:
Delphi-Quellcode:
begin
Query1.Params.ParamByName ('param1').AsString := 'blubb';
end;
Vorher sage ich meinem
Query mit
ParamCheck := True; das es die Parameter auch bitte auswerten soll.
Der Vorteil der Parameter ist das ich mich nicht darum kümmern muss das sie in der für meine Datenbank richtigen Formatierung benutzt werden. Wenn Du das ganze ohne Parameter machen möchtest, musst Du es ja so schreiben:
Delphi-Quellcode:
begin
Query1.Close;
Query1.SQL.Text := 'SELECT * FROM tabelle WHERE name = ' + QuotedStr ('blubb');
Query1.Open;
end;
Sprich: Bei einem Stringvergleich möchte die Datenbank das der String in Hochkommas steht. Ein noch besseres Beispiel sind Datumsabfragen:
Delphi-Quellcode:
begin
Query1.Close;
Query1.SQL.Text := 'SELECT * FROM tabelle WHERE datum = ' + DateToStr (now);
Query1.Open;
end;
Wenn Du das so machst bekommst Du aller Warscheinlichkeit einen Fehler

Auf den meisten Rechnern ist noch die alte Datumsanzeige eingestellt. (TT.MM.JJJJ = 01.07.2004) Der
mySQL-Server möchte das Datum aber in diesem Format: "JJJJ-MM-TT = 2004-07-01". Jetzt hast Du natürlich die Möglichkeit das Datum immer entsprechend zu Formatieren.
Delphi-Quellcode:
begin
Query1.Close;
Query1.SQL.Text := 'SELECT * FROM tabelle WHERE datum = ' + FormatDateTime ('yyyy-mm-dd',now);
Query1.Open;
end;
Bei der Verwendung von Parametern musst Du dich darum nicht kümmern.
Delphi-Quellcode:
begin
Query1.Close;
Query1.SQL.Text := 'SELECT * FROM tabelle WHERE datum = :mydatum';
Query1.ParamCheck := True;
Query1.Params.ParamByName('myDatum').AsDate := now;
Query1.Open;
end;
Soviel zu den Parameter.
Stephan B.
"Lasst den Gänsen ihre Füßchen"