Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Delphi: Базы данных и репортинг > Параметры Query из запроса


Автор: harakiri 8.1.2013, 11:48
Здравствуйте уважаемые форумчане. Созрел вопрос, с которым я не могу разобраться самостоятельно. Есть БД Access, приложение на делфи, на DataModule лежит frxReport. Есть идея в БД создать отдельную таблицу в которой будут храниться запросы для построения отчетов. Ну например запись в таблице следующего вида:
Код

SELECT o.DateOut FROM Operation o WHERE o.ID = :ID
 
Данная строка считывается из БД и передается в Query для выполнения этого же запроса. Собственно сам вопрос, каким образом можно из данной строки определить количество нужных запросу параметров, их имена и передать им данные? И возможна ли вообще реализация такой затеи. Простите если не совсем внятно объяснил вопрос, старался как мог smile Заранее спасибо.

Автор: Данкинг 8.1.2013, 12:06
Цитата(harakiri @  8.1.2013,  12:48 Найти цитируемый пост)
Простите если не совсем внятно объяснил вопрос

Точно: я вот ничего не понял. smile 
Наводящие вопросы:
1) В каком виде хранятся данные в таблице с параметрами?
2) Где именно требуется считать параметры?

Автор: Vas 8.1.2013, 12:40
Цитата(harakiri @  8.1.2013,  11:48 Найти цитируемый пост)
Собственно сам вопрос, каким образом можно из данной строки определить количество нужных запросу параметров

Посчитать. 
А если серьезно, то присвой своему ADOQuery запрос в рантайме, сделай ему Prepare и посмотри в цикле какие параметры распарсил сам Query. Читай их и передавай им значения.

Добавлено через 6 минут и 5 секунд
Пардон, слегка обманул, не Prepare делать надо, а ParseSQL
Код

  ADOQuery1.Parameters.ParseSQL(ADOQuery1.SQL.Text, True);
  ADOQuery1.Parameters.ParamByName('DateBeg').Value:=FormatDateTime('dd.mm.yyyy',DlgGReport.FrameDateEnter1.DateTimePicker1.Date)+' 00:00:00';
  ADOQuery1.Parameters.ParamByName('DateEnd').Value:=FormatDateTime('dd.mm.yyyy',DlgGReport.FrameDateEnter1.DateTimePicker2.Date)+' 23:59:59';

Автор: Akella 8.1.2013, 14:26
Цитата(harakiri @  8.1.2013,  11:48 Найти цитируемый пост)
каким образом можно из данной строки определить количество нужных запросу параметров

У квери есть ParamCount.

Автор: harakiri 8.1.2013, 15:30
Структура таблицы Reports:
1. IDRep
2.NameRep
3.QueryText

По нажатии на батон, я передаю MainQuery параметр NameRep, и выбираю из таблицы Reports текст запроса:
Код

SELECT r.QueryText FROM Reports r WHERE r.NameRep = :NameRep


Далее результат я присваиваю компоненту Query следующее:
Код


RepQuery.SQL.Add(MainRep.FieldValues['QueryText']) ;


И получается, что у RepQuery(запрос на основе результатов которого будет строиться отчет) SQL будет равен, ну например
Код

SELECT o.DateOut FROM Operation o WHERE o.ID = :ID and o.DateIn = :DateIn


Но заведомо я не знаю, какой именно запрос будет передаваться в RepQuery и сколько параметров у него будет. Вот как-то так. Наверное я еще больше запутал. smile 

Автор: Vas 9.1.2013, 11:30
Цитата(harakiri @  8.1.2013,  15:30 Найти цитируемый пост)
Но заведомо я не знаю, какой именно запрос будет передаваться в RepQuery и сколько параметров у него будет. Вот как-то так. Наверное я еще больше запутал.

уже сказали вот
Цитата(Vas @  8.1.2013,  12:40 Найти цитируемый пост)
Пардон, слегка обманул, не Prepare делать надо, а ParseSQL



Цитата(harakiri @  8.1.2013,  15:30 Найти цитируемый пост)
о заведомо я не знаю, какой именно запрос будет передаваться в RepQuery и сколько параметров у него будет.

тоже уже сказали
Цитата(Akella @  8.1.2013,  14:26 Найти цитируемый пост)
У квери есть ParamCount. 


Или за вас весь код написать?

Автор: harakiri 9.1.2013, 22:54
Vas, нет весь код я писать не просил. Спасибо. Разобрался.

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)