AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Code-Bibliothek Library: Datenbanken Delphi Struktur einer Tabelle auslesen
Thema durchsuchen
Ansicht
Themen-Optionen

Struktur einer Tabelle auslesen

Ein Thema von Cuchulainn · begonnen am 14. Jan 2004
Antwort Antwort
Cuchulainn

Registriert seit: 26. Aug 2003
182 Beiträge
 
Delphi 5 Enterprise
 
#1

Struktur einer Tabelle auslesen

  Alt 14. Jan 2004, 07:32
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]
  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 16:46 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