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

Вниз

Куда исчезают параметры TADOStoredProc?   Найти похожие ветки 

 
Bless1   (2004-03-04 12:44) [0]

Люди, кто может объяснить мне причины следующего явления:
Есть объект proc1: TADOStoredProc;
В design-time свойство ProcedureName проинициализировано именем некоторой хранимой процедуры, принимающей в качестве параметра число.
Соответственно, в parameters этот параметр видно.Но если запустить программу на выполнение и сделать proc1.execProc, то она вылетает с сообщением об ошибке "parameter not found".
Действительно, в  WatchList proc1.parameters.count=0.
Почему? Куда девались параметры?
Причем, для одних ADOStoredProc такая ошибка выскакивает, для других - нет.
И даже для тех, для которых ошибка выскакивает, она внезапно исчезает. По непонятным для меня причинам.
От ошибки можно излечиться, если на форму кинуть еще одну
ADOStoredProc и настроить ее на ту же хп (помогает не всегда).
Или если настроить на эту же хп одну из уже существующих,  корректно работающих ADOStoredProc.
Причем правильно работать начинает и та proc1, которая до этого не работала. И продолжает правильно работать, даже если удалить "лечащую" ADOStoredProc.

Кто может объяснить сей феномен?


 
Users   (2004-03-04 13:42) [1]

Лучше всего всегда при инициализации модуля, формы и т.д. делать

1 ) Устанавливать Connection;
2 ) Присваивать название процедуры;
1 ) ADOStoredProc1.Parameters.Refresh;
2 ) Заполнять ВСЕ параметры процедуры значениями указанными на сервере в качестве умолчательных.

Почему могут пропадать параметры : смена названия процедуры.


 
Nikolay M. ©   (2004-03-04 16:07) [2]

Да, есть такое. Что обидно: корпоративная политика запрещала пользоваться алиасами и, тем более, ODBC-шными DSN-ами, а вот как раз через них все работало. Далеко в исходники залезть не получилось, поэтому пришлось работать через TQuery. Обидно, а что делать :(


 
Bless1   (2004-03-04 17:33) [3]

to Users>
ADOStoredProc1.Parameters.Refresh помогло. Спасибо.

Но все-равно, почему параметры исчезали? Название процедуры я не менял: то, что в design-time поставил, то и оставалось.

>2 ) Заполнять ВСЕ параметры процедуры значениями указанными на
>сервере в качестве умолчательных.

А это зачем?


 
Users   (2004-03-04 18:38) [4]

Смысл такой - если у сторед процедуры есть 10 параетров, а ты работаешь всего с 1-м инициализировать необходимо всегда ВСЕ!

Собственно если работаешь с 1-м параметром, остальные 9 заполняешь умолчательными параметрами.

Если этого не делать возникает ошибка на Windows 2003 Server - пока только на этой ос. Там возникает AV в dll (*ado*.dll точно не помню) при чтении/записи по 0 адресу - скорее всего из за передачи параметров в dll через стек. Стали заполнять все параметры - ошибки исчезли.

Тут по этому поводу пост был сегодня.


 
Users   (2004-03-04 18:39) [5]

Вот пост :

http://delphimaster.net/view/3-1078392079/


 
Bless1   (2004-03-06 09:22) [6]

to User> Спасибо.



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

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

Наверх




Память: 0.48 MB
Время: 0.024 c
1-1079599458
Alex*
2004-03-18 11:44
2004.04.04
Excel добавление столбца


6-1075112970
AlexDBases
2004-01-26 13:29
2004.04.04
Запуск приложения на удалённом компьютере.


3-1078512059
dma_database
2004-03-05 21:40
2004.04.04
TTable TDataBase


1-1079498494
Malax
2004-03-17 07:41
2004.04.04
Копирование и запуск приложения


1-1079610606
Marser
2004-03-18 14:50
2004.04.04
Межплатформенный перенос