AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Query mit Parameterübergabe und Sonderzeichen im Wert
Thema durchsuchen
Ansicht
Themen-Optionen

Query mit Parameterübergabe und Sonderzeichen im Wert

Ein Thema von Moony · begonnen am 6. Jan 2012 · letzter Beitrag vom 10. Jan 2012
 
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: Query mit Parameterübergabe und Sonderzeichen im Wert

  Alt 6. Jan 2012, 15:04
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)
  Mit Zitat antworten Zitat
 


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:04 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 by Thomas Breitkreuz