Главная страница
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.062 c
15-1173276490
Sam Stone
2007-03-07 17:08
2007.04.01
Miranda 0.6.7


3-1168319296
Loginov Dmitry
2007-01-09 08:08
2007.04.01
Медленно изменяются записи при включенном CachedUpdates


6-1161065329
Lilu
2006-10-17 10:08
2007.04.01
Indy10 + Thread


15-1172755279
Галинка
2007-03-01 16:21
2007.04.01
Чем можно нагреть газ до 700 градусов


2-1173306689
Ezorcist
2007-03-08 01:31
2007.04.01
сколько в памяти займет integer ?