Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Tabellennamen aus einer TDatabase in eine Stringlist? (https://www.delphipraxis.net/56045-tabellennamen-aus-einer-tdatabase-eine-stringlist.html)

Bigeddie 31. Okt 2005 09:21

Datenbank: MySQL • Version: 4-1-14 • Zugriff über: MySQL ODBC 3.51

Tabellennamen aus einer TDatabase in eine Stringlist?
 
Hallo,

Ich möchte über ein TDatabase alle Tabellennamen über GetTableNames in eine Stringlist auslesen.
Leider erhalte ich immer eine Fehlermeldung wenn ich

Delphi-Quellcode:
MyDatabase.GetTableNames(MyList,false);
aufrufe.

MyList ist vom Type TStringlist, da es sich dabei TStrings um eine abstrakte Klasse handelt, aber was mache ich falsch?

Gruß

Bigeddie

marabu 31. Okt 2005 09:40

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Hallo Bigeddie,

du hast zwar vergessen die Fehlermeldung mitzuteilen, aber es kommen in erster Linie nur zwei Fehler in Frage: du hast die StringList nicht vorher erzeugt oder die Database-Komponente ist noch nicht im Zustand Connected.

Grüße vom marabu

Bigeddie 31. Okt 2005 09:55

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Danke hat funktioniert, dachte aber da ich nur, daß ich eine direkte referenz auf die Liste in TDatabase bekommen würde und nicht extra ein Objekt bräuchte in welches eine Kopie der Liste übertragen wird.

Gruß
Bigeddie

WIng2005 4. Jun 2007 10:17

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Delphi-Quellcode:
Procedure PAdminDBViewer_Main;
var SL:TStringList;
Begin
mainform.Notebook1.ActivePage:='PAdminDBViewer';

begin

  SL:=TStringList.Create;
  try
    Mainform.ZConnection1.GetTableNames(SL, False);

    Mainform.Memo1.lines.add('Folgende Tabellen sind vorhanden:');
     Mainform.Memo1.lines.Addstrings(SL);
  finally
    SL.free;
  end;
end;


end;
Bei mir kommt immer: [Fehler] PAdminDBViewer.pas(24): Es gibt keine überladene Version von 'GetTableNames', die man mit diesen Argumenten aufrufen kann

Nutze D7 und Zeos auf MYSQL

MFG
Steffen

marabu 4. Jun 2007 10:23

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Hallo Steffen,

was passiert, wenn du beim Aufruf von GetTableNames() die richtigen Argumente übergibst?

Delphi-Quellcode:
procedure GetTableNames(const Pattern: string; List: TStrings);
Freundliche Grüße

WIng2005 4. Jun 2007 10:34

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Fehler entdeckt:

Mainform.ZConnection1.GetTableNames(SL, False);
in
Mainform.ZConnection1.GetTableNames('',SL);

geändert und geht. Kann es sein, das die, in der Doku gezeigte Syntax von GettableNames
bei SQLConnection eine ander ist, als die, für die TZConnection ?

MFG
Steffen

mkinzler 4. Jun 2007 10:36

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Zitat:

bei SQLConnection eine ander ist, als die, für die TZConnection ?
Ja

marabu 4. Jun 2007 10:36

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Genau so ist es.

WIng2005 4. Jun 2007 10:52

Re: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Na dann .... Stunden verschenkt.... :wall:

Wie auch immer, nun gehts ja..

Dank euch trotzdem.

MFG
Steffen

Jens Hartmann 8. Jan 2011 10:35

AW: Tabellennamen aus einer TDatabase in eine Stringlist?
 
Liste der Anhänge anzeigen (Anzahl: 1)
Hallo zusammen,

ich muss dieses Thema hier mal kurz aufgreifen. Warum kommt bei unten gezeigter Methoden die Fehlermeldung im Anhang?

Delphi-Quellcode:
procedure TForm8.FormCreate(Sender: TObject);
var
  FTableList : TStringList;
  i : Integer;
begin
  FTableExist := False;
  FTableList := TStringList.Create;
  try
    dbMon1.FileName := 'MyAppLog.log';
    dbMon1.Active  := True;
    dbMon1.AutoSave := True;
    dbCon1.Connect;
    dbCon1.GetTableNames('',FTableList);
  finally
    FTableList.Free;
  end;
end;
Die Logdatei zeigt folgendes:
Zitat:

08.01.2011 11:32:41: CONNECT TO "PSSecur" AS USER "SYSDBA"
08.01.2011 11:32:41: TRANSACTION STARTED.
08.01.2011 11:32:41: SELECT DISTINCT a.RDB$RELATION_NAME, a.RDB$SYSTEM_FLAG, a.RDB$VIEW_SOURCE, a.RDB$DESCRIPTION FROM RDB$RELATIONS a
und in der Zeile...

Delphi-Quellcode:
    dbCon1.GetTableNames('',FTableList);
passiert der Fehler.:gruebel:

Gruß Jens


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:36 Uhr.
Seite 1 von 2  1 2      

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