Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.04.01;
Скачать: CL | DM;

Вниз

Подскажите можно ли из DBGrid-а узнать какую таблицу он отражает?   Найти похожие ветки 

 
Lamer666   (2007-01-08 01:53) [0]

ПРИВЕТ НАРОД! ВСЕМ РЕСПЕКТ!!!
Подскажите можно ли из DBGrid-а узнать какую таблицу он отражает?
ADOConnection->ADOQuery->DataSourese->DBGrid


 
sniknik ©   (2007-01-08 01:59) [1]

через раз, чаще всего нельзя, хотябы попросту потому, что отображается view или процедура, или вообще не связанный с базой рекордсет.


 
Lamer666   (2007-01-08 02:02) [2]

А из Query который поставляет данный в DBGrid?


 
Германн ©   (2007-01-08 02:07) [3]


> Lamer666   (08.01.07 02:02) [2]
>
> А из Query который поставляет данный в DBGrid?
>

А что Query всегда связан с одной таблицей?


 
sniknik ©   (2007-01-08 02:10) [4]

а какая разница? запрос он и есть запрос, и он только в крайне малом количестве случаев прямое отражение таблицы.
гарантировано только для ADO в случае с типом команды = cmdTable/cmdDirectTable можно узнать.


 
Lamer666   (2007-01-08 02:14) [5]


> А что Query всегда связан с одной таблицей?

Логично!!!!


 
Lamer666   (2007-01-08 02:15) [6]

Ну ХОРОШО, натом СПАСИБО!


 
MsGuns ©   (2007-01-08 16:45) [7]

Можно узнать КАКИМ ОБРАЗОМ получен датасет, проанализировав TDBGrid.DataSource.DataSet.
Для этого нужно сначала определить какого он класса (используя св-во ClassType или ClassName).
Если это TXXTable, то, в зависимости от типа компоненты доступа, можно "вытащить" и имя таблицы.
Если не TXXTable, то "вытащить" текст запроса (св-во SQL, CommandText или другие).
Затем полученный текст просканировать в поисках того, что стоит за Select  From. Если запрос простой, то, как правило, то, что стоит за выражением From до первого пробела и есть имя таблицы (таблиц) или ХП(функции, представления и т.д.).
Далее просто. Полученное имя ищем среди списка таблиц БД, котороый легко получить. Если нашли, то это и есть та самая таблица

Хотя, в общем случае, это сделать весьма затруднительно, иногда невозможно. Да и не нужно это.
Есть предположение, что ы хотите написать некоторый универсальный код, который сможет работать с любым НД и которому передается не датасет, а собственно грид.
В этом случае Вам не нужно знать имя таблицы. Достаточно иметь лишь указатель на датасет для того, чтобы управлять им (поиски, сортировки, фильтры и т.д.)


 
Lamer666   (2007-01-08 19:52) [8]

ТАК И СДЕЛАЛ, УВАЖАЕМЫЙ!!!! РЕСПЕКТ!



Страницы: 1 вся ветка

Текущий архив: 2007.04.01;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.044 c
1-1170660674
DelphiLexx
2007-02-05 10:31
2007.04.01
Узнать программно имя unit a


15-1173308821
mr 666
2007-03-08 02:07
2007.04.01
Где в WinXP


8-1154176268
DLag
2006-07-29 16:31
2007.04.01
Захват картинки с окна через DirectX


15-1173418402
sportman
2007-03-09 08:33
2007.04.01
Акт внедрения программного продукта


6-1161425591
Yegorchic
2006-10-21 14:13
2007.04.01
IdHTTP: сколько байт получено/отправлено