AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi ClientDataSet mit zwei Filtern
Thema durchsuchen
Ansicht
Themen-Optionen

ClientDataSet mit zwei Filtern

Ein Thema von H.Bothur · begonnen am 19. Jun 2017 · letzter Beitrag vom 21. Jun 2017
Antwort Antwort
Seite 2 von 2     12   
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#11

AW: ClientDataSet mit zwei Filtern

  Alt 20. Jun 2017, 13:27
Was erwartest du denn bei Memo1.Text := 'WHERE feld = ' + QuotedStr('Das ist ein Text mit '' und \ drin'); ?

Code:
Input: WHERE feld = Das ist ein Text mit " , ' und \ drin

Pascal (QuotedStr: WHERE feld = 'Das ist ein Text mit " , '' und \ drin'

SQL (EscapeValue): WHERE feld = 'Das ist ein Text mit " , \' und \\ drin'

SQL (EscapeName): WHERE feld = "Das ist ein Text mit \" , ' und \\ drin"
Bestimmt was Anderes als ich.

FilterText erwartet einen Text nach der Definition für SQL-Strings.
QuotedStr erzeugt aber einen Text nach der Definition für Pascal-Strings.
Und die sind nicht kompatibel, wenn es um Steuerzeichen geht.
$2B or not $2B

Geändert von himitsu (20. Jun 2017 um 13:56 Uhr)
  Mit Zitat antworten Zitat
H.Bothur

Registriert seit: 25. Jun 2012
Ort: Seevetal & Lagos
257 Beiträge
 
Delphi 11 Alexandria
 
#12

AW: ClientDataSet mit zwei Filtern

  Alt 20. Jun 2017, 13:53
OK - Danke !

Das wusste ich natürlich nicht.

Hans
Hans-Georg Bothur
www.hermann-juergensen.de
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

Registriert seit: 24. Okt 2006
Ort: Seifhennersdorf / Sachsen
5.388 Beiträge
 
Delphi 12 Athens
 
#13

AW: ClientDataSet mit zwei Filtern

  Alt 20. Jun 2017, 15:58
@himitsu:
Zitat:
FilterText erwartet einen Text nach der Definition für SQL-Strings.
...wo hast du das her? Die Doku incl. dem Beispiel sagt was anderes.
http://docwiki.embarcadero.com/Libra...DataSet.Filter
Delphi-Quellcode:
with ADODataSet1 do begin
Filtered := False;
Filter := 'State = ' + QuotedStr('CA') + ' OR ' +
'State = ' + QuotedStr('CA');
Filtered := True;
end;
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.184 Beiträge
 
Delphi 12 Athens
 
#14

AW: ClientDataSet mit zwei Filtern

  Alt 21. Jun 2017, 10:39
Nur weil in der Doku etwas Falsches drin steht, heißt es noch lange nicht, dass es richtig ist.

Wie gesagt, QuotedStr hat ein anderes Verhalten beim Quoting/Escaping, welches nicht zu einem SQL-Statement passt.

Leider bringt Delphi nativ keine passenden SQL-Funktionen dafür mit, was auch ein bisschen verständlich ist, da es je nach DBMS/Dialekt leichte Unterschiede gibt. (wenn man damit sein SELECT zusammenbauen wöllte)
Aber bezüglich DataSet.Filter weiß ich jetzt nicht, ob das wirklich vom DBMS abhängt ... scheint ja meinstens nur eine Implementation im Delphi zu sein, welches eine minimale Untermenge der im SQL92 enthaltenen Möglichkeiten für ein WHERE-Statement darstellt, welches man quasi mit AND an das WHERE anghängen würde.

So lange keine Steuerzeichen oder irgendwas exotisches verwendet wird, also praktisch nur ASCII ohne ' / " und C0, dann gibt es keine Probleme.
$2B or not $2B

Geändert von himitsu (21. Jun 2017 um 10:51 Uhr)
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 2 von 2     12   


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 20:21 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