AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi SQL - Datenbanken auslesen ...
Thema durchsuchen
Ansicht
Themen-Optionen

SQL - Datenbanken auslesen ...

Ein Thema von Ricane · begonnen am 4. Aug 2003 · letzter Beitrag vom 5. Aug 2003
 
Benutzerbild von Ricane
Ricane

Registriert seit: 21. Mär 2003
Ort: Quickborn
170 Beiträge
 
Delphi 7 Architect
 
#4

Re: SQL - Datenbanken auslesen ...

  Alt 4. Aug 2003, 14:33
Die Lösung:
(für das auslesen von allen Datenbanken und Tabellen von einem Server)

Als erstes lesen wir die Datenbanken aus. Dazu erstellen wir uns den ConnectionString, den wir dann unserer ADOConnection zuweisen.
Code:
"Server" ist ein aktiver SQL - Server
"cbDatenbank" ist eine ComboBox
"Auselsen" ist eine Stringvariable.

  ServerTyp := 'SQLOLEDB.1';

  ConnectionString :=
        'Provider=' + ServerTyp + ';Integrated Security=SSPI;Persist Security ' +
    'Info=False;Initial Catalog=Master;Data Source=' + Server + ';' +
    'Use Procedure for Prepare=1;Auto Translate=True;Packet Size=4096;' +
    'Use Encryption for Data=False;Tag with column collation when possible=False';

  // Connectionstring zuweisen und in der nächsten Zeile verbinden
  Db_DataModule.DataModule1.ADOConnection1.ConnectionString := ConnectionString;
  Db_DataModule.DataModule1.ADOConnection1.Connected := True;

  (* 
     "siCatalogs" steht für die Datenbanken. Es wird dann erstmal alles in das
     Hauptgrid geschoben, vom wo es dann in die Liste exportiert wird.
  *)

  Db_DataModule.DataModule1.ADOConnection1.OpenSchema(siCatalogs, null, EmptyParam, Db_DataModule.DataModule1.ADODataSet1);
  while not Db_DataModule.DataModule1.ADODataSet1.EOF do
  begin
    Auslesen := Db_DataModule.DataModule1.ADODataSet1.Fields[0].AsString;
    cbDatenbank.Items.Add(Auslesen);
    Db_DataModule.DataModule1.ADODataSet1.Next;
  end;
Nachdem das geschafft ist, können jetzt alle USER - Tabellen (die SYSTEM - Tabellen werden nicht berücksichtigt!) von der Datenbank geladen werden.

Code:
Tabellen ist einen StringList.
I ist eine Integer Variable.
"cbTabellen" ist eine ComboBox.

  if Db_DataModule.DataModule1.ADOConnection1.Connected = False then
    Exit;

  // StringListe erstellen.
  Tabellen := TStringList.Create;
  // Tabellennamen laden.
  Db_DataModule.DataModule1.ADOConnection1.GetTableNames(Tabellen, False);
  // Anzeigen
  for I := 0 to (Tabellen.Count - 1) do
  begin
    cbTabellen.Items.Add(Tabellen[I]);
  end;
der Rest dürfte nicht mehr so schwer sein... Hoffe ich konnte auch endlich mal jemanden helfen!


Ricane
Hendrik
So much to Code... so less Time....

www.RicaneSoftware.de
  Mit Zitat antworten Zitat
 


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 09:36 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