was ist neu ¦  programmier tips ¦  indy artikel ¦  intraweb artikel ¦  informationen ¦  links ¦  interviews
 sonstiges ¦  tutorials ¦  Add&Win Gewinnspiel

Tips (1541)

Dateien (137)
Datenbanken (90)
Drucken (35)
Grafik (114)
IDE (21)
Indy (5)
Internet / LAN (130)
IntraWeb (0)
Mathematik (76)
Multimedia (45)
Oberfläche (107)
Objekte/
ActiveX (51)

OpenTools API (3)
Sonstiges (126)
Strings (83)
System (266)
VCL (242)

Tips sortiert nach
Komponente


Tip suchen

Tip hinzufügen

Add&Win Gewinnspiel

Werbung

75 Visitors Online


 
...alle Tabellen einer Datenbank mit ADO ermitteln?
Autor: Carlo Pasolini, Riccione(Italy)
[ Tip ausdrucken ]  

Tip Bewertung (23):  
     


//How to retrieve all database tables with ADO

unit dbTables;

interface

uses 
ADODb;

type
  
TTableType = (ttTable, ttView, ttSynonym, ttSystemTable, ttAccessTable);

type
  
TTableTypes = set of TTableType;

type
  
TTableItem = record
    
ItemName: string;
    ItemType: string;
  end;

type
  
TTableItems = array of TTableItem;

function addFilter(string1, string2: string): string;
function ADODbTables(ADOConnection: TADOConnection; types: TTableTypes): TTableItems;

implementation

function 
addFilter(string1, string2: string): string;
begin
  if 
string1 <> '' then
    
Result := string1 + ' or ' + string2
  else
    
Result := string2;
end;

function ADODbTables(ADOConnection: TADOConnection; types: TTableTypes): TTableItems;
var
  
ADODataSet: TADODataSet;
  i: integer;
begin
  
ADODataSet := TADODataSet.Create(nil);
  ADODataSet.Connection := ADOConnection;
  ADOConnection.OpenSchema(siTables, EmptyParam, EmptyParam, ADODataSet);

  if (ttTable in types) then
    
ADODataSet.Filter := addFilter(ADODataSet.Filter, '(TABLE_TYPE = ''TABLE'')');

  if (ttView in types) then
    
ADODataSet.Filter := addFilter(ADODataSet.Filter, '(TABLE_TYPE = ''VIEW'')');

  if (ttSynonym in types) then
    
ADODataSet.Filter := addFilter(ADODataSet.Filter, '(TABLE_TYPE = ''SYNONYM'')');

  if (ttSystemTable in types) then
    
ADODataSet.Filter := addFilter(ADODataSet.Filter, '(TABLE_TYPE = ''SYSTEM TABLE'')');

  if (ttAccessTable in types) then
    
ADODataSet.Filter := addFilter(ADODataSet.Filter, '(TABLE_TYPE = ''ACCESS TABLE'')');

  ADODataSet.Filtered := True;

  SetLength(Result, ADODataSet.RecordCount);

  i := 0;
  with ADODataSet do
  begin
    
First;
    while not EOF do
    begin
      with 
Result[i] do
      begin
        
ItemName := FieldByName('TABLE_NAME').AsString;
        ItemType := FieldByName('TABLE_TYPE').AsString;
      end;
      Inc(i);
      Next;
    end;
  end;

  ADODataSet.Free;
end;

end.

{
Example: create a new project and add a TADOConnection (ADOConnection1),
a TButton (Button1) and a TMemo (Memo1); assign a ConnectionString to the
TADOConnection component and set "ADOConnection1.Active := True"
}

procedure TForm1.Button1Click(Sender: TObject);
var
  
output: ttableitems;
  i: integer;
begin
  
output := ADODbTables(ADOConnection1, [ttTable, ttView, ttSynonym]);
  //  output := ADODbTables(ADOConnection1, [ttSystemTable, ttAccessTable]);
  
for i := Low(output) to High(output) do
  begin
    
Memo1.Lines.Add(output[i].ItemName + '---' + output[i].ItemType);
  end;
  output := nil;
end;


 

Bewerten Sie diesen Tipp:

dürftig
ausgezeichnet


Copyright © by SwissDelphiCenter.ch
All trademarks are the sole property of their respective owners