Also zum einen würde ich so schon mal nicht durch die Parameter iterieren
Besser so:
Delphi-Quellcode:
var
ParamName : string;
ParamIdx : integer;
ParamValue : string;
for i := 0 to myDS.ParamCount - 1 do
begin
ParamName := myDS.Params[ i ].Name;
ParamIdx := ParamFieldsLst.IndexOf( ParamName );
if ( ParamIdx >= 0 ) and ( ParamIdx < ParamValuesLst.Count ) then
begin
ParamValue := ParamValuesLst[ ParamIdx ];
myDS.Params[ i }.Value := ParamValue;
end
else
myDS.Params[ i ].Clear;
end;
warum so ... weil dann auch das hier möglich ist:
Code:
SELECT * FROM foo WHERE name1 LIKE :Parameter OR name2 LIKE :Parameter
Für die Suche mit LIKE müsstest du aber auch die Joker % oder _ verwenden, oder du bekommst nur 100% übereinstimmende Treffer. Auch dieses kann ein Grund dafür sein, dass du keine Treffer bekommst.
Wenn der Wert also irgendwie in dem Feld auftauchen soll, dann musst du also so vergleichen lassen:
Code:
SELECT * FROM foo WHERE name1 LIKE "%Müller%"
Mein Beispiel damit erweitert würde dann wie folgt aussehen:
Delphi-Quellcode:
var
ParamName : string;
ParamIdx : integer;
ParamValue : string;
for i := 0 to myDS.ParamCount - 1 do
begin
ParamName := myDS.Params[ i ].Name;
ParamIdx := ParamFieldsLst.IndexOf( ParamName );
if ( ParamIdx >= 0 ) and ( ParamIdx < ParamValuesLst.Count ) then
begin
ParamValue := ParamValuesLst[ ParamIdx ];
myDS.Params[ i }.Value := '%' + ParamValue + '%';
end
else
myDS.Params[ i ].Clear;
end;
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ea 0a 4c 14 0d b6 3a a4 c1 c5 b9
dc 90 9d f0 e9 de 13 da 60)