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

Вниз

Статический и динамический запросы   Найти похожие ветки 

 
Kley   (2007-04-12 21:00) [0]

Здравствуйте подскажите плиз
На форме есть PageControl с двумя TabSheet на которых лежит по DbGridEh
связанные с datamodule1.PrihodQuery. на открытие первого TabSheet выполняется статический запрос
со следующими параметрами:
procedure TForm2.sTabSheet1Show(Sender: TObject);
begin
Screen.Cursor := crHourGlass;
datamodule1.PrihodQuery.Parameters.ParamByName("D").Value:="01.01."+idag;
datamodule1.PrihodQuery.Parameters.ParamByName("D1").Value:= datetostr (Date);
datamodule1.PrihodQuery.Parameters.ParamByName("A").Value:=2;
datamodule1.PrihodQuery.Parameters.ParamByName("S").Value:=100;
datamodule1.PrihodQuery.Parameters.ParamByName("F").Value:=0;
datamodule1.PrihodQuery.Parameters.ParamByName("F1").Value:=1;
datamodule1.PrihodQuery.Open;
datamodule1.PrihodQuery.Requery;
Screen.Cursor := crDefault;
end;
на открытие второго TabSheet выполняется динамический запрос следующего вида:
procedure TForm2.sTabSheet2Show(Sender: TObject);
begin
Screen.Cursor := crHourGlass;
datamodule1.PrihodQuery.Close;
datamodule1.PrihodQuery.SQL.Clear;
datamodule1.PrihodQuery.SQL.Add("select *");
datamodule1.PrihodQuery.SQL.Add("from prihodz WHERE DATEX>=:D3 AND DATEX<=:D4 and ACTIONX=2 AND S1>SOPLATA");
datamodule1.PrihodQuery.Parameters.ParamByName("D3").Value:=sdateedit1.Date;
datamodule1.PrihodQuery.Parameters.ParamByName("D4").Value:=sdateedit2.Date;
datamodule1.PrihodQuery.Open;
Screen.Cursor := crDefault;
end;
после открытия второго TabSheet прехожу на первый TabSheet возникает ошибка -не найден параметр D
как с этим бороться?


 
Desdechado ©   (2007-04-12 21:05) [1]

Ну так у тебя используется один и тот же компонент datamodule1.PrihodQuery, текст запроса в котором затирается второй закладкой. Естественно, на первой уже ничего сделать нельзя.

ЗЫ Вместо вот этого "01.01."+idag, datetostr (Date) используй нормальные "дата"-значения, а не строки. Тем более раз параметры используешь.


 
Johnmen ©   (2007-04-12 21:31) [2]


> datamodule1.PrihodQuery.Requery;

А это зачем после Open?


 
Kley   (2007-04-12 21:32) [3]

>>Ну так у тебя используется один и тот же компонент >>datamodule1.PrihodQuery, текст запроса в котором затирается второй >>закладкой.
Вто то и дело что желательно один Query использовать.
>>Естественно, на первой уже ничего сделать нельзя.
не ужели действительно сделать ничего нельзя? Не затирается же он совсем
восстанавливается както при закрытии и открытии программы.


 
Kley   (2007-04-12 21:55) [4]

>>> datamodule1.PrihodQuery.Requery;

>>А это зачем после Open?
извиняюсь запарился.


 
Desdechado ©   (2007-04-13 11:32) [5]

> Вто то и дело что желательно один Query использовать.
Используй. Но только помни, что на "заранее в дизайне прописанный запрос" полагаться уже нельзя. Нужно будет его прописывать в коде на каждой закладке свой. Т.е. так, как у тебя сделано на 2-й закладке.

> Не затирается же он совсемвосстанавливается както при закрытии и открытии программы.
Что-то разводом попахивает.
Ты давно программируешь? Пора бы уже понять, что изменение значения переменных во время выполнения программы не сказывается на содержимом EXE. Поэтому при "открытии" программы переменные имеютте значения, которые ты им прописал в дизайне.



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

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

Наверх




Память: 0.48 MB
Время: 0.014 c
15-1181812261
Sir John
2007-06-14 13:11
2007.07.15
Срочно нужен толковый флэшер


15-1180461426
TStas
2007-05-29 21:57
2007.07.15
Научиться ли писать на С++? Стоит ли это делать?


2-1182625728
Gringoire
2007-06-23 23:08
2007.07.15
Картинки и БД


15-1181982335
zvm
2007-06-16 12:25
2007.07.15
кто-нибудь знает реально, как сделать HELP


2-1182464746
Lokk83
2007-06-22 02:25
2007.07.15
Обновление DBGRID по таймеру