Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Library: Datenbanken (https://www.delphipraxis.net/22-library-datenbanken/)
-   -   Delphi Daten aus einem DataSet in TEdit/TListView anzeigen (https://www.delphipraxis.net/90749-daten-aus-einem-dataset-tedit-tlistview-anzeigen.html)

tr909 23. Apr 2007 10:31


Daten aus einem DataSet in TEdit/TListView anzeigen
 
Ich hab mal einen kleinen Schnippsel um die Daten aus einem DataSet in Edit-Feldern anzuzeigen.
Übergeben werden mus der Name der Form, Das DataSet, dann noch das Feld in dem ein eindeutiger Wert steht(pk) sowie der gesuchte Wert (value)

Delphi-Quellcode:
function FillToEdit(frm: TForm;ds : TDataSet;pk,value: string):boolean;
{**************************************************************************
 Zeigt ausgewählten Datensatz in namensgleichen Edit-Feldern an.
**************************************************************************}
var
  i: Integer;
begin
  result := true;
  if ds.Locate(pk,value,[]) then
  begin
    for i:=0 to frm.ComponentCount-1 do
      begin
        if frm.Components[i] is TEdit then
        begin
          if ds.FieldDefs.IndexOf(frm.Components[i].Name) <> -1 then
          TEdit(frm.Components[i]).Text :=
            ds.FieldByName(frm.Components[i].Name).AsString;
        end;
      end;
  end
  else
    result := false;
end;
In dem Array cols werden die Feldnamen die im ListView angezeigt werden sollen übergeben. das Feld pk wird nicht mit angezeigt, aber gespeichert. Dort kann der eindeutige Wert um den Datensatz zu identifizieren abgelegt werden.

Delphi-Quellcode:
procedure FillListView (cols:array of string;pk: string;lv: TListView;ds : TDataSet);
{**************************************************************************
 Zeigt ausgewählte Datensätze eines Datasets in einem ListView an.
**************************************************************************}
var
  NewItem: TListItem;
  i: integer;
begin
  with ds do
  begin
    First;
    lv.Items.Clear;
    lv.ViewStyle := vsReport;
    lv.RowSelect := true;
    for i := 0 to length(cols)-1 do
    begin
      lv.Columns.Add();
      lv.Column[i].Caption := cols[i];
    end;
    while not eof do
    begin
      NewItem := lv.Items.Add;
      NewItem.Caption := FieldByName(cols[0]).AsString;
      for i := 1 to length(cols)-1 do
        NewItem.SubItems.Add(FieldByName(cols[i]).AsString);
      NewItem.SubItems.Add(FieldByName(pk).AsString);
      Next;
    end;
  end;
end;
Gruß
tr909


Alle Zeitangaben in WEZ +1. Es ist jetzt 19:53 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