AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

DevExpress: DBView-FilterRow ohne Wildcard

Ein Thema von haentschman · begonnen am 17. Apr 2023 · letzter Beitrag vom 17. Apr 2023
Antwort Antwort
Benutzerbild von haentschman
haentschman

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

DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 09:37
Hallöle...

Ich brauche in der Filterliste ein "Like". Mit %Value% funktioniert das. Das verstehen die User aber nicht. Ich möchte: Bei Eingabe "Bla" Ergebnis aus der Datenmenge 'MeinBla', 'BlaBlubb' haben.

Bei DevExpress gibt es diesen Eintrag:
https://supportcenter.devexpress.com...-or-like-value
created 15 years ago...mit weiterführenden Links. Alle sind imho nicht zielführend. ...Endlosschleife von Link zu Link.

Ich habe gefühlt alle Filtereinstellungen durch.

Hat jemand eine Idee.

Danke.

Version: 21.2.9

CrossPost: englische DP https://en.delphipraxis.net/topic/87...hout-wildcard/
Miniaturansicht angehängter Grafiken
filter.png  

Geändert von haentschman (17. Apr 2023 um 10:59 Uhr)
  Mit Zitat antworten Zitat
Delphi.Narium

Registriert seit: 27. Nov 2017
2.528 Beiträge
 
Delphi 7 Professional
 
#2

AW: DevExpress: FilterRow ohne Wildcard

  Alt 17. Apr 2023, 10:36
Wie sieht denn die Eingabemöglichkeit aus Usersicht aus?

Ein Edit, in dem der gesamte Filter eingegeben wird oder ein Edit / Combobox für das Feld und ein Edit für den Suchbegriff, ...

Verstehen denn die User den * als Platzhalter?

Z. B.:Feld = '*Bla*' ? Dann könntest Du im Programm den Filter entsprechend in Feld like '%Bla%' umbauen?

Oder soll sowieso grundsätzlich per Like gesucht werden?

Dann bietet es sich wirklich an, die Feldauswahl per ComboBox anzubieten und den Suchbegriff per Edit. Dann hast Du ggfls. auch Einfluss auf eventuell im Suchbegriff enthaltene ' und die User müssen sich nicht angewöhnen im Filter ggfls. '' einzugeben, wenn like und % auch schon etwas zuviel verlangt sind.
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#3

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 11:02
Meinst du wirklich die FilterRow?
Da hat man irgendwann mal eine sinnvolle Erweiterung implementiert:
GridView.FilterRow.OperatorCustomization := True;
Frank
Frank Reim
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

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

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 11:12

Wir reden über die FilterRow in der Grid View.

* es soll grundsätzlich "%Value%" zur Datenbank "gesendet" werden, aber in der FilterRow soll nur "Value" angezeigt werden...% = hidden
Zitat:
Da hat man irgendwann mal eine sinnvolle Erweiterung implementiert
...ist grundsätzlich abgelehnt worden. Die gibt es im Programm nur als "Option"...keiner hat es aktiv!
Miniaturansicht angehängter Grafiken
filterleiste.png  

Geändert von haentschman (17. Apr 2023 um 11:31 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#5

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 11:34
Da bleibt wohl nur, die Spalten der Grid zu iterieren und den Operator zu setzen:
GridColumn.Options.FilterRowOperator := foContains;
Frank
Frank Reim
  Mit Zitat antworten Zitat
Benutzerbild von haentschman
haentschman

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

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 12:25
...habe ich gemacht.

Delphi-Quellcode:
colStore.Options.FilterRowOperator := foContains;
...
...keine Änderung der Funktion. Kein "contains".

1. Eingabe string "56"
* Autovervollständigung mit 2x "0"
* Entferung der 2x "0"
* Enter
-> Bild: leer

2. Eingabe string "%56%"
* Enter
-> Bild: Match

Das Ergebnis hätte ich gern immer...
Miniaturansicht angehängter Grafiken
auto.png   leer.png   match.png   columnoptions.png  

Geändert von haentschman (17. Apr 2023 um 12:32 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 13:40
Ja, das ist ja doof...

Er ignoriert das, wenn GridView.FilterRow.OperatorCustomization False ist.
Hier könnte man mal bei DevExpress anfragen - aber das dauert auch meist ewig.
Das Standardverhalten sollte man eigentlich beeinflussen können.
Leider ist DevExpress bei Anfragen zu Änderungen manchmal ziemlich "zickig"...

Frank
Frank Reim
  Mit Zitat antworten Zitat
Benutzerbild von Stevie
Stevie

Registriert seit: 12. Aug 2003
Ort: Soest
4.034 Beiträge
 
Delphi 10.1 Berlin Enterprise
 
#8

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 16:25
Damit foContains funktioniert, muss das Feld ein TextFeld sein, ist es das? Ggf musst du explicit die Properties Eigenschaft der Column setzen, ansonsten nimmt das Grid anhand des Feld- bzw Datatyps einen Default.
Stefan
“Simplicity, carried to the extreme, becomes elegance.” Jon Franklin

Delphi Sorcery - DSharp - Spring4D - TestInsight
  Mit Zitat antworten Zitat
Benutzerbild von dataspider
dataspider

Registriert seit: 9. Nov 2003
Ort: 04539 Groitzsch
1.351 Beiträge
 
Delphi 11 Alexandria
 
#9

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 17:22
Delphi-Quellcode:
function TcxGridFilterRow.GetOperator(Index: Integer; AValue: Variant): TcxFilterOperatorKind;
var
  AFilterCriteriaItem: TcxFilterCriteriaItem;
begin
  if GridView.FilterRow.OperatorCustomization then
  begin
    ....
  end
  else
    Result := GetDefaultFilterOperatorKind(AValue, True);
end;

function TcxGridFilterRow.GetDefaultFilterOperatorKind(const AValue: Variant; ACheckMask: Boolean): TcxFilterOperatorKind;

  function HasMask(const AValue: string): Boolean;
  begin
    Result :=
      (Pos(DataController.Filter.PercentWildcard, AValue) <> 0) or
      (Pos(DataController.Filter.UnderscoreWildcard, AValue) <> 0);
  end;

begin
  if VarIsStr(AValue) and (not ACheckMask or HasMask(AValue)) then
    Result := foLike
  else
    Result := foEqual;
end;
In den Sourcen von DevExpress sieht man, dass es nur funktioniert, wenn GridView.FilterRow.OperatorCustomization True ist.
Man muss also mit den Symbolen in der FilterRow leben (siehe Anhang) oder auf Contains verzichten.
Standard bei Text ist dann foLike...


Frank
Miniaturansicht angehängter Grafiken
filter_contains.jpg  
Frank Reim
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: DevExpress: DBView-FilterRow ohne Wildcard

  Alt 17. Apr 2023, 17:47
Gibt es kein CustomDraw dafür?
$2B or not $2B
  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 00:11 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