Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Library: Datenbanken (https://www.delphipraxis.net/22-library-datenbanken/)
-   -   Delphi Struktur einer Tabelle auslesen (https://www.delphipraxis.net/14687-struktur-einer-tabelle-auslesen.html)

Cuchulainn 14. Jan 2004 06:32


Struktur einer Tabelle auslesen
 
Mit dieser Funktion kann man die Struktur einer db-Tabelle auslesen. Sie gibt von jedem Feld der Tabelle die Nummer, den Feldnamen und den Fildtyp zurück.
Der Funktion wird der Pfad und der Name der Tabelle übergeben. Die Struktur wird in der globalen Stringliste slErgebnis gespeichert, die Funktion gibt einen String zurück. Entweder 'Ok', wenn kein Fehler aufgetreten ist, oder einen Fehlertext, der in der Funktion festgelegt wird.

Delphi-Quellcode:
function TFrmStruktur.FktStruktur(StrDateiname: String):String;
var
  IntZaehler:Integer;
  sType:String;
begin
  try
    result:='undefinierter Fehler';
    slErgebnis.clear;
    try
      TblTabelle.close;
      TblTabelle.tablename := StrDateiname;
      TblTabelle.Open;
    except
      result:='Fehler beim lesen der Datei !'
    end;

    // Die Struktur wird in der Stringliste slErgebnis gespeichert
    for IntZaehler:=0 to TblTabelle.FieldCount-1 do
    begin
      case TblTabelle.Fields[IntZaehler].datatype of
        ftUnknown : begin sType:='Unknown'; end;
        ftString : begin sType:='String'; end;
        ftSmallint : begin sType:='Smallint'; end;
        ftInteger : begin sType:='Integer'; end;
        ftWord : begin sType:='Word'; end;
        ftBoolean : begin sType:='Boolean'; end;
        ftFloat : begin sType:='Float'; end;
        ftCurrency : begin sType:='Currency'; end;
        ftBCD : begin sType:='BCD'; end;
        ftDate : begin sType:='Date'; end;
        ftTime : begin sType:='Time'; end;
        ftDateTime : begin sType:='DateTime'; end;
        ftBytes : begin sType:='Bytes'; end;
        ftVarBytes : begin sType:='VarBytes'; end;
        ftAutoInc : begin sType:='AutoInc'; end;
        ftBlob : begin sType:='Blob'; end;
        ftMemo : begin sType:='Memo'; end;
        ftGraphic : begin sType:='Graphicc'; end;
        ftFmtMemo    : begin sType:='FmtMemo'; end;
        ftParadoxOle : begin sType:='ParadoxOlee'; end;
        ftDBaseOle : begin sType:='DBaseOle'; end;
        ftTypedBinary : begin sType:='TypedBinary'; end;
        ftCursor : begin sType:='Cursor'; end;
        ftFixedChar : begin sType:='FixedChar'; end;
        ftWideString : begin sType:='WideString'; end;
        ftLargeInt : begin sType:='LargeInt'; end;
        ftADT : begin sType:='ADT'; end;
        ftArray : begin sType:='Array'; end;
        ftReference : begin sType:='Reference'; end;
        ftDataSet : begin sType:='DataSet'; end;
        ftOraBlob : begin sType:='OraBlob'; end;
        ftOraClob : begin sType:='OraClob'; end;
        ftVariant : begin sType:='Variant'; end;
        ftInterface : begin sType:='Interface'; end;
        ftIDispatch : begin sType:='IDispatch'; end;
        ftGuid : begin sType:='Guid'; end;
      end;
      slErgebnis.add(inttostr(IntZaehler)+#9+TblTabelle.Fields[IntZaehler].FieldName+#9+sType+#9+
        inttostr(TblTabelle.Fields[IntZaehler].size));
    end;
    if slErgebnis.Count>0 Then
      result:='OK';
  finally
  end;
end;
[edit=Matze][code] durch [delphi]-Tags ersetzt und Code formatiert. Mfg, Matze[/edit]


Alle Zeitangaben in WEZ +1. Es ist jetzt 13:42 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-2025 by Thomas Breitkreuz