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

Вниз

"Залипание" данных при вызове Хранимой процедуры   Найти похожие ветки 

 
pic509 ©   (2006-09-05 15:42) [0]

Столкнулся с такой проблемой: у меня есть Хранимая процедура с входными параметрами (некоторые из них по умолчанию = null). При первом вызове ХП ExecProc выбираются нужные мне данные. Делаю Close. Затем, сменив данные входных параметров, снова вызываю ХП. И получаю старые данные! Как заставить ХП сбросит предыдущий результат???


 
evvcom ©   (2006-09-05 15:48) [1]

> [0] pic509 ©   (05.09.06 15:42)
> При первом вызове ХП ExecProc

Это по-моему в ODAC ExecProc вызывает внутри себя Open. Лучше сам сразу Open вызывай, оно так нагляднее и всем привычнее.

> Затем, сменив данные входных параметров, снова вызываю ХП.
> И получаю старые данные!

Чудес не бывает. Какие компоненты доступа? Если ODAC, поставь Debug := True; и удивись.


 
pic509 ©   (2006-09-05 15:54) [2]

Пробовал Open. Тот же эффект. Я использую BDE.


 
evvcom ©   (2006-09-05 16:05) [3]

> [2] pic509 ©   (05.09.06 15:54)
> Я использую BDE.

Все равно чудес не бывает. Значит в Watch посмотри перед Open, что там в параметрах. А лучше сначала протестируй свою ХП в родной среде разработки. Чего у тебя там? Какая СУБД?


 
pic509 ©   (2006-09-05 16:08) [4]

Совсем забыл: я пишу в Делфи 5, база на MS SQL 2000


 
pic509 ©   (2006-09-05 16:47) [5]

Просмотрел входные параметры через SQL-monitor:
при первом вызове, к примеру передается параметр №1. Следующий вызов передает параметр №3. Но параметр №1 каким-то образом сохраняется!?
Как сделать инициализацию (сброс) входных параметров ХП. Делать влоб ...ParamByName("name").value=null мне кажется не красиво и громоздко. Можно ли одной командой сделать сброс?


 
ANB ©   (2006-09-05 16:49) [6]


> Пробовал Open. Тот же эффект. Я использую BDE.

Вот тута проблема и порылась.


 
Val ©   (2006-09-05 17:04) [7]

код покажите.


 
evvcom ©   (2006-09-05 17:09) [8]

> [5] pic509 ©   (05.09.06 16:47)
> Но параметр №1 каким-то образом сохраняется!?

Как это "каким-то образом"? А кто его оттуда вычищал?

> Как сделать инициализацию (сброс) входных параметров ХП.
> Делать влоб ...ParamByName("name").value=null мне кажется
> не красиво

Напиши свою процедурину для очистки всех параметров и вызывай при необходимости. В ней цикл по всем и Params[i].Clear;


 
pic509 ©   (2006-09-05 17:12) [9]

Сделал так. Все работает. Спасибо!!!



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

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

Наверх




Память: 0.49 MB
Время: 0.074 c
15-1160474069
Vlad Oshin
2006-10-10 13:54
2006.10.29
Про отца. Мини-рассказ


2-1160628993
Serg_e
2006-10-12 08:56
2006.10.29
Как заставить работать tab MDIChild-форме?


15-1160330633
vidiv
2006-10-08 22:03
2006.10.29
как в MS OutLook повторно отправить письмо?


6-1149591835
Comrade
2006-06-06 15:03
2006.10.29
Количество траффика из Инета


15-1160303268
kaif
2006-10-08 14:27
2006.10.29
Клубная культура