AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Thema durchsuchen
Ansicht
Themen-Optionen

VIEW erkennen

Ein Thema von Aenogym · begonnen am 16. Mai 2006 · letzter Beitrag vom 16. Mai 2006
Antwort Antwort
Benutzerbild von Aenogym
Aenogym

Registriert seit: 7. Mär 2004
Ort: Schwerin
1.089 Beiträge
 
Delphi 7 Enterprise
 
#1

VIEW erkennen

  Alt 16. Mai 2006, 16:00
Datenbank: Access • Version: 2000 • Zugriff über: ADO (Jet 4)
hi ihr,

ich habe in meiner access-datenbank ein view. wenn ich mir per TADOConnection.GetTableNames() die namen der tabellen ausgeben lasse, dann ist in dieser liste auch mein view drin. soweit so gut.
nur: wie kann ich erfahren, ob es sich bei einem eintrag in dieser liste um eine tabelle oder ein view handelt (ist mir zur entwurfszeit nicht bekannt)?

danke schonmal,
aeno
Steffen Rieke
Was nicht buzzt, wird buzzend gemacht!
http://blog.base-records.de
http://www.base-records.de
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#2

Re: VIEW erkennen

  Alt 16. Mai 2006, 16:46
das geht über ADOX.

Delphi-Quellcode:
uses ADOX_TLB; // Typbibliothek, muss zuvor importiert werden

var
   ADOXcatalog : _Catalog;

....
   ADOXcatalog := CoCatalog.Create; // in FormCreate
....
   ADOXcatalog.Set_ActiveConnection(ADOConnection1.ConnectionObject);
....

function IsView(const TableName:string):Boolean;
var
   i : Integer;
   T : Tables;
begin
   T := ADOXcatalog.Tables;

   for i := 0 to T.Count-1 do
   begin
      if T.Item[i].Name = TableName then
      begin
         Result := Pos('VIEW', T.Item[i].Type_) > 0;
         Exit;
      end;
   end;
   Result := False;
end;
Andreas
  Mit Zitat antworten Zitat
marabu

Registriert seit: 6. Apr 2005
10.109 Beiträge
 
#3

Re: VIEW erkennen

  Alt 16. Mai 2006, 19:47
Hallo.

Als Alternative zu ADOX kann man auch den Provider befragen:

Delphi-Quellcode:
function GetTableType(conn: TADOConnection; sTable: String): String;
var
  ds: TADODataSet;
begin
  ds := TADODataSet.Create(nil);
  ds.Connection := conn;
  conn.OpenSchema(siTables, EmptyParam, EmptyParam, ds);
  ds.Open;
  if ds.Locate('TABLE_NAME', sTable, [])
    then Result := ds.FieldValues['TABLE_TYPE']
    else Result := '';
  ds.Close;
  ds.Free;
end;
Freundliche Grüße vom marabu
  Mit Zitat antworten Zitat
Benutzerbild von Aenogym
Aenogym

Registriert seit: 7. Mär 2004
Ort: Schwerin
1.089 Beiträge
 
Delphi 7 Enterprise
 
#4

Re: VIEW erkennen

  Alt 16. Mai 2006, 20:04
danke euch beiden! das werd ich dann morgen gleich ausprobieren.

aenogym
Steffen Rieke
Was nicht buzzt, wird buzzend gemacht!
http://blog.base-records.de
http://www.base-records.de
  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 06:11 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