Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Welches Tabellenfeld gehort zu welcher Tabelle? (https://www.delphipraxis.net/91404-welches-tabellenfeld-gehort-zu-welcher-tabelle.html)

LuckySpacy 4. Mai 2007 11:58

Datenbank: Microsoft SQL Server • Zugriff über: ADO/ODBC

Welches Tabellenfeld gehort zu welcher Tabelle?
 
Hallo
Ich habe in einer Delphi-Form eine Memo-Box, eine ADOConnection, ADODataset und ein DBGrid.
ADOConnection.Provider = MSDASQL (ODBC)

Der Benutzer soll die Möglichkeit haben, in der Memo-Box SQL-Anweisungen selbst zu erstellen.
Sobald er die SQL-Anweisung abschickt, soll das Ergebnis in der DBGrid sichtbar sein.
Wenn der Benutzer in das DBGrid klickt, dann möchte ich gerne die Feldeigenschaften (Feldtyp, Feldgröße, null erlaubt, primary feld usw.) des jeweiligen Tabellenfeldes anzeigen.
Die Feldeigenschaften möchte ich aus den Systemtabellen der Datenbank ermitteln.

Soweit so gut.

Mein Problem:
Wenn der Benutzer jetzt mehrere Tabellen miteinander in der SQL-Anweisung verbindet, woher weiß ich jetzt welches Tabellenfeld zu welcher Tabelle gehört?.
Dies ist ja notwendig, um die Feldeigenschaften richtig ermitteln zu können.

Gibt es ein Möglichkeit (vielleicht direkt mit ADO) herauszufinden, welches Feld aus der SQL-Anweisung aus welcher Tabelle kommt?

marabu 4. Mai 2007 12:21

Re: Welches Tabellenfeld gehort zu welcher Tabelle?
 
Hallo,

ich fürchte da wirst du einen anderen Weg gehen müssen. Nicht zuletzt weil auch der SQL-Server bei einer unqualifizierten JOIN-Anfrage die beteiligten Tabellen abklappert bis er das Feld findet, sind solche Queries nicht updatefähig.

MSSQL und ADO - da ist übrigens ADOX das Mittel der Wahl um Kataloginformationen zu lesen: klick

Grüße vom marabu


Alle Zeitangaben in WEZ +1. Es ist jetzt 06:03 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