AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Tabellen einer DB auflisten über ADO
Thema durchsuchen
Ansicht
Themen-Optionen

Tabellen einer DB auflisten über ADO

Ein Thema von Jelly · begonnen am 27. Sep 2005 · letzter Beitrag vom 27. Sep 2005
Antwort Antwort
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#1

Tabellen einer DB auflisten über ADO

  Alt 27. Sep 2005, 09:29
Datenbank: MSSQL • Version: 2000 • Zugriff über: ADO
Ich sitz grad etwas auf dem Schlauch. Über folgende Methode liste ich mir alle Tabellenfelder in eine StringList. Das klappt auch.
Delphi-Quellcode:
procedure TMailFieldName.FillFieldNames (Names : TStringList) ;
var
  aRS : _RecordSet;
  aOleV : OleVariant;
  sSQL : string ;
  FConnection : string ;
  Info : TMailDatabaseInfo ;
  i : integer ;
begin
  aRS := CoRecordSet.Create;
  aRS.CursorLocation := adUseServer;
  Info := TMailDatabaseInfo (GetComponent(0)) ;
  with Info do begin
     sSQL := format('select * from %s where 1=2',
                    [Tablename]
                    ) ;
     FConnection := ConnectionString ;
  end ;
  try
    aRS.Open(sSQL, FConnection,adOpenStatic, adLockReadOnly, adCmdText);
    Names.clear ;
    for i := 0 to aRS.Fields.Count-1 do
       Names.Add (aRS.Fields[i].Name) ;
  finally
    aRS.Close;
  end;
end;
Ich bin mit diesen ganzen ADO Sachen nicht so vertraut. Ich suche jetzt was Ähnliches. Will aber nicht die Felder einer Tabelle auflisten sondern alle Tabellen einer Datenbank. Am liebsten natürlich unabhängig vom DB System.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#2

Re: Tabellen einer DB auflisten über ADO

  Alt 27. Sep 2005, 09:41
Hai Jelly,

meinst Du das so wie es die Methode [oh].GetTableNames();[/oh] der ADOConnection macht?;
Delphi-Quellcode:
procedure TForm1.ADOConnection1AfterConnect(Sender: TObject);
begin
  ADOConnection1.GetTableNames(lb_Tabellen.Items);
end;
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#3

Re: Tabellen einer DB auflisten über ADO

  Alt 27. Sep 2005, 09:46
Genau. Nur dass ich eben nicht mit TADODataset arbeite.
  Mit Zitat antworten Zitat
Benutzerbild von Sharky
Sharky

Registriert seit: 29. Mai 2002
Ort: Frankfurt
8.251 Beiträge
 
Delphi 2006 Professional
 
#4

Re: Tabellen einer DB auflisten über ADO

  Alt 27. Sep 2005, 10:17
Zitat von Jelly:
Genau. Nur dass ich eben nicht mit TADODataset arbeite.
Hmm... zumindest für den MS-SQL würdes Du die Tabellen einer Datenbank so bekommen müssen:
SELECT * FROM datenbank.INFORMATION_SCHEMA.TABLES
Stephan B.
"Lasst den Gänsen ihre Füßchen"
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#5

Re: Tabellen einer DB auflisten über ADO

  Alt 27. Sep 2005, 10:43
Hab mich an die TADOConnection.GetTablesNames angelehnt, und bin zu folgendem funktionierendem Code gelangt.
Delphi-Quellcode:
procedure TMailTableName.FillTableNames(Names: TStringList);
var
  aRS : _RecordSet;
  aConn : _Connection ;
  aOleV : OleVariant;
  sSQL : string ;
  FConnection : string ;
  Info : TMailDatabaseInfo ;
  i : integer ;
  TypeID, NameID : integer ;
  TableType : string ;
begin
  Info := TMailDatabaseInfo (GetComponent(0)) ;
  aRS := CoRecordSet.Create;
  aConn := CoConnection.Create as _Connection ;


  try
    aConn.ConnectionString := Info.ConnectionString ;
    aConn.Open(Info.ConnectionString, '', '', adConnectUnspecified);

    aRS := aConn.OpenSchema(adSchemaTables,EmptyParam,EmptyParam) ;
    TypeID := -1 ;
    NameID := -1 ;
    Names.clear ;

    for i := 0 to aRS.Fields.Count-1 do begin
       if uppercase(aRS.Fields[i].Name) = 'TABLE_TYPEthen TypeID := i ;
       if uppercase(aRS.Fields[i].Name) = 'TABLE_NAMEthen NameID := i ;
    end ;

    while not aRS.EOF do begin
        TableType := uppercase (aRS.Collect[TypeID]) ;
        if ((TableType = 'TABLE') or (TableType = 'VIEW'))
            and (TableType <> 'SYSTEM TABLE') and (TableType <> 'SYSTEM VIEW')
        then Names.Add(aRS.Collect[NameID]) ;
        aRS.MoveNext ;
    end ;
    aRS.Close;
    aConn.close ;
  except

  end;
end;
Klappt zumindest für den MSSQL Server einwandfrei... Sollte aber prinzipiell auch für andere DB klappen.
  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 13:51 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