Главная страница
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-1181633805
IMHO
2007-06-12 11:36
2007.07.15
С Днем России, россияне!


1-1178402176
Драйвер
2007-05-06 01:56
2007.07.15
Поделитесь функцией HSV to RGB на Паскале ?


15-1182177008
oldman
2007-06-18 18:30
2007.07.15
Все-таки в правильной области я работаю...


2-1182266516
AlexanderMS
2007-06-19 19:21
2007.07.15
Сохранение настроек программы в её исполняемом файле.


3-1176875990
Юрий
2007-04-18 09:59
2007.07.15
Многотабличный запрос (MySQL)