![]() |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Zitat:
Gruß K-H |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Die Grids von Embarcadero sind Schrott (vorallem VCL) und können so einfache Dinge nicht, wie z.B. das Sortieren und Filtern ... da muß man das dann im DataSet machen (besser aber schon im Query, bevor es im DataSet landet).
|
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Zitat:
Zitat:
Gruß K-H |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Himitsu hat schon Recht mit den Emba-Grids.
Die DB-Admins sehen es nicht gerne, wenn bei jedem Klick auf ein Header des DBGrid eine neue Query (mit neuer Sortierung) vom Server abgerufen wird. Das gibt Traffic ... Dann lieber die Abfrage in einem ClientDataSet mit verschiedenen Indexen definieren und dieses dann nach jedem Header-Click mit dem entsprechenden Index "sortieren". Sollte dann alles lokal ablaufen. |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Zitat:
Aber warum sollte ich das machen, wenn es auch so geht. Ich hatte hier in gewisser Hinsicht den Ansatz einer nicht sortierten Stringlist im Kopf, wo man ja auch per .exchange oder .move die einzelnen Zeilen / Datensätze an andere Positionen verschieben kann. Ein Problem bezüglich Trennung von Daten und Anzeige sehe ich bei meinem Ansatz übrigens nicht. Denn es werden ja keine Daten im Grid gespeichert, ich ändere nur die unter dem Grid liegende Datenschicht, die Anzeige im Grid passt sich automatisch an. Da es im vorliegenden Fall auch nur um eine lokale Verwaltung eines kleinen Datenbestandes geht, keine echte Datenbank dahinter liegt (benutze nur ClientDataset und Datasource) und somit auch keine Client-Server Abfragen oder ähnliches erforderlich sind, sehe ich hier kein Problem. Lasse mich aber gerne eines Besseren belehren. |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Zitat:
|
AW: ClientDataset: Wie Record verschieben oder Position tauschen
OK, ich müsste aber manuell den Index-Filter verwalten, wenn ich z.B. per Drag & Drop eine Zeile an eine andere Position verschiebe, z.B. von 100 auf 4. Oder? Das wäre wieder zusätzlich Aufwand. Würde ich ja machen, wenn ich einen zusätzlichen Nutzen bei dieser Lösung erkennen würde.
Das Speichern vom ClientDataset in die Stringlist mache übrigens wie nachfolgend. Habe ich hier evtl. typische Anfängerfehler drin, bzw. geht es einfacher? Z.B. würde mich interessieren, muss ich immer erst den Filter ausschalten, um wieder die volle Anzahl der Records zu bekommen oder gibt es eine andere Variante, um durch den ganzen Datenbestand zu iterieren?
Delphi-Quellcode:
procedure TF_ConvertList.SaveClientDataSetToStringList;
var L, x, c, current: Integer; s: string; Filterstatus: Boolean; begin current := cds1.RecNo; cds1.DisableControls; FilterStatus := cds1.Filtered; cds1.Filtered := false; try cds1.MergeChangeLog; c := cds1.FieldCount; slProp.Clear; cds1.First; for L := 0 to cds1.RecordCount-1 do begin S := ''; for x := 0 to c-1 do begin if x = c-1 then begin S := S + cds1.Fields[x].Text; end else begin S := S + cds1.Fields[x].Text + #1; end; end; slProp.Add(S); cds1.Next; end; slProp.SaveToFile(CurrentFileName); finally cds1.EnableControls; end; cds1.Filtered := FilterStatus; if Current <> -1 then cds1.RecNo := Current; end; |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
So ist es meiner Meinung nach etwas einfacher.
Delphi-Quellcode:
var
current: Integer; Filterstatus: Boolean; fld: TField; linelist: TStringList; datalist: TStringList; begin current := cds1.RecNo; FilterStatus := cds1.Filtered; cds1.DisableControls; try cds1.Filtered := false; cds1.MergeChangeLog; datalist := TStringList.Create; try linelist := TStringList.Create; try linelist.Delimiter := #1; linelist.StrictDelimiter := true; cds1.First; while not cds1.Eof do begin linelist.Clear; for fld in cds1.Fields do begin linelist.Add(fld.Text); end; datalist.Add(linelist.DelimitedText); cds1.Next; end; finally linelist.Free; end; datalist.SaveToFile(CurrentFileName); finally datalist.Free; end; finally cds1.Filtered := FilterStatus; cds1.EnableControls; end; if Current <> -1 then cds1.RecNo := Current; end; |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
@Uwe: Danke für die Optimierungshinweise.
Mit anderen Worten, es gibt keine einfachere Variante, um auf die Datensätze innerhalb des Clientdataset zuzugreifen. Ist jetzt kein Drama, aber wenn es eine Möglichkeit gegeben hätte, wäre es gut, das zu wissen. |
AW: ClientDataset: Wie Record verschieben oder Position tauschen
Noch einfacher wäre es nur, wenn das Dateiformat nicht vorgegeben wäre. Wir benutzen einfach die integrierte Methode zum Speichern und Laden von XML Dateien. Das hat den angenehmen Nebeneffekt, dass auch die Feldinformationen schon automatisch dabei sind usw. und es ist eben nur die eine Zeile Quelltext jeweils.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:48 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