AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein ClientDataSet in mehreren Spalten suchen
Thema durchsuchen
Ansicht
Themen-Optionen

ClientDataSet in mehreren Spalten suchen

Ein Thema von Luki206 · begonnen am 4. Jul 2014 · letzter Beitrag vom 4. Jul 2014
Antwort Antwort
Luki206
(Gast)

n/a Beiträge
 
#1

ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:19
Hi DP, wie kann man mit dem ClientDataSet mehrere Spalten durchsuchen sprich, beide Spalten müssen meinen Kriterien entsprechen. Ich habe auch schon gegoogled aber wahrscheinlich nach dem Falschen..
Danke
Luki
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:26
Das geht, wie in jedem anderen DataSet auch, indem man mehrere Namen und Werte übergibt.

Delphi-Quellcode:
Locate('feld', wert, ...)
Locate('feld1;feld2', VarArrayOf([wert1, wert2]), ...)
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.

Geändert von himitsu ( 4. Jul 2014 um 18:45 Uhr)
  Mit Zitat antworten Zitat
Luki206
(Gast)

n/a Beiträge
 
#3

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:33
Oh ok, danke

PS: Ich dachte das geht in die Richtung mit Locate(Feld1 and Feld2, Wert1 and Wert2, ...

Edit: ich bekomme den Fehler
Code:
[dcc32 Fehler] haupt.pas(213): E2010 Inkompatible Typen: 'array of Variant' und 'string'

Geändert von Luki206 ( 4. Jul 2014 um 18:37 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:36
Oh ok, danke

PS: Ich dachte das geht in die Richtung mit Locate(Feld1 and Feld2, Wert1 and Wert2, ...
Ja, so steht das ja auch in der Dokumentation Delphi-Referenz durchsuchenTDataSet.Locate, oder etwa doch anders?
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
Benutzerbild von himitsu
himitsu

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:42
Edit: ich bekomme den Fehler
Code:
[dcc32 Fehler] haupt.pas(213): E2010 Inkompatible Typen: 'array of Variant' und 'string'
Dann machst du was falsch?
Aber ich kann jetzt nciht sagen was, da ich ja nicht weiß was du genau machst.


Es geht natürlich auch so Locate('feld1,feld2', [wert1, wert2]) , wobei hier , und ; als Trennzeichen erlaubt sind und man sich um das Array nicht selber kümmern muß.
Man kann eventuell auch noch Leerzeichen entfernen, womit dann auch 'feld1, feld2' ginge, falls man eine bessere Tennung mag.
Delphi-Quellcode:
type
  TDataSetHelper = class helper for TDataSet
    function Locate(const KeyFields: string; const KeyValues: Variant): Boolean; overload;
    function Locate(const KeyFields: string; const KeyValues: array of Variant; Options: TLocateOptions=[]): Boolean; overload;
    function Lookup(const KeyFields: string; const KeyValues: array of Variant; const ResultFields: string): Variant; overload;
  end;

function TDataSetHelper.Locate(const KeyFields: string; const KeyValues: Variant): Boolean;
begin
  Result := Locate(KeyFields, KeyValues, []);
end;

function TDataSetHelper.Locate(const KeyFields: string; const KeyValues: array of Variant; Options: TLocateOptions): Boolean;
begin
  Result := Locate(ReplaceStr(KeyFields, ',', ';'), VarArrayOf(KeyValues), Options);
end;

function TDataSetHelper.Lookup(const KeyFields: string; const KeyValues: array of Variant; const ResultFields: string): Variant;
begin
  Result := Lookup(ReplaceStr(KeyFields, ',', ';'), VarArrayOf(KeyValues), ResultFields);
end;
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Luki206
(Gast)

n/a Beiträge
 
#6

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:43
Ok, danke. Der Fehler hat sich erübrigt, habe anscheinend nur eckige Klammern vergessen
  Mit Zitat antworten Zitat
Benutzerbild von himitsu
himitsu

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 18:44
Ja, so steht das ja auch in der Dokumentation Delphi-Referenz durchsuchenTDataSet.Locate, oder etwa doch anders?
Es kommt drauf an, welche Doku du davon verwendest. (z.B. die vom TBDEDataSet)


[edit] Ups. Ja, die Klammern vergessen.
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 19:13
Ja, so steht das ja auch in der Dokumentation Delphi-Referenz durchsuchenTDataSet.Locate, oder etwa doch anders?
Es kommt drauf an, welche Doku du davon verwendest. (z.B. die vom TBDEDataSet)
Die eine ist mit "Bildern" und die andere nur mit Beschreibung ... die Aussagen sind aber gleich.
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
Benutzerbild von himitsu
himitsu

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

AW: ClientDataSet in mehreren Spalten suchen

  Alt 4. Jul 2014, 19:16
Ahhh, hab's im TDataSet.Locate gefunden ... siehe "Siehe auch"
Neuste Erkenntnis:
Seit Pos einen dritten Parameter hat,
wird PoSex im Delphi viel seltener praktiziert.
  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:19 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