Экспертная система Delphi.int.ru

Сообщество программистов
Общение, помощь, обмен опытом

Логин:
Пароль:
Регистрация | Забыли пароль?

Delphi.int.ru Expert

Другие разделы портала

Переход к вопросу:

#   

Статистика за сегодня:  


Лучшие эксперты

Подробнее »



Вопрос # 821

/ вопрос открыт /

Разбираю чужой исходник программы для работы с БД SQL
Работа с таблицами происходит примерно следующим образом:
есть рабочии таблицы и таблицы со служебной информацией, форма для просмотра таблицы формируется динамически.
Но совсем не пойму следующий фрагмент кода(см. приложение)

Приложение:
  1. QueryCol.Close;
  2. QueryCol.SQL.Clear;
  3. QueryCol.SQL.Add('select o_t1.id id0, o_t1.table_name, o_t1.name, ');
  4. QueryCol.SQL.Add('o_t2.table_name main_t, o_t2.name main_t_rus, o_t3.table_name dop_t, ');
  5. QueryCol.SQL.Add('o_t3.name dop_t_rus, dopt.num_t, o_c.* ');
  6. QueryCol.SQL.Add('from dbo.obj_doptables dopt, dbo.obj_tables o_t1, dbo.obj_tables o_t2, ');
  7. QueryCol.SQL.Add('dbo.obj_tables o_t3, dbo.obj_columns o_c ');
  8. QueryCol.SQL.Add('where o_t1.id = dopt.obj_tables_id ');
  9. QueryCol.SQL.Add('and o_t2.id = dopt.main_table ');
  10. QueryCol.SQL.Add('and o_t3.id = dopt.dop_table ');
  11. QueryCol.SQL.Add('and dopt.main_table = o_c.obj_tables_id ');
  12. QueryCol.SQL.Add('order by dopt.obj_tables_id, dopt.num_t, o_c.id');
  13. QueryCol.Open;


taran Вопрос ожидает решения (принимаются ответы, доступен мини-форум)

Вопрос задал: taran (статус: Посетитель)
Вопрос отправлен: 2 августа 2007, 11:23
Состояние вопроса: открыт, ответов: 1.

Ответ #1. Отвечает эксперт: Помфюк Владимир Степанович

Здравствуйте, taran!
Запрос деактивируется, текст запроса очищается, строчка за строчкой формируется новый текст запроса, потом запрос активируется. Текст запроса - в приложении, если что-то непонятно в нём - sorry, для разбора нужно знать какая СУБД используется, так как судя по префиксу "dbo." запрос идёт к системным таблицам.

Приложение:
  1. select o_t1.id id0, o_t1.table_name, o_t1.name,
  2. o_t2.table_name main_t, o_t2.name main_t_rus, o_t3.table_name dop_t,
  3. o_t3.name dop_t_rus, dopt.num_t, o_c.*
  4. from dbo.obj_doptables dopt, dbo.obj_tables o_t1, dbo.obj_tables o_t2,
  5. dbo.obj_tables o_t3, dbo.obj_columns o_c
  6. where o_t1.id = dopt.obj_tables_id
  7. and o_t2.id = dopt.main_table
  8. and o_t3.id = dopt.dop_table
  9. and dopt.main_table = o_c.obj_tables_id
  10. order by dopt.obj_tables_id, dopt.num_t, o_c.id
  11.  


Ответ отправил: Помфюк Владимир Степанович (статус: Абитуриент)
Время отправки: 2 августа 2007, 11:56
Оценка за ответ: 4


Мини-форум вопроса

Мини-форум пуст.

Чтобы оставлять сообщения в мини-форумах, Вы должны авторизироваться на сайте.

Версия движка: 2.6+ (26.01.2011)
Текущее время: 4 июня 2023, 19:47
Выполнено за 0.01 сек.
Рейтинг@Mail.ru