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

Вниз

TStoredProc.Params.CreateParam странно выполняеться...   Найти похожие ветки 

 
Cheg ©   (2002-12-24 12:13) [0]

Привет всем. Проблема такая, почему когда я создаю параметры для TStoredProc в порядке отличном от порядка параметров в самой сохраненной процедуре, то процедура выполняеться(или невыполняеться вообще) неправильно. Все параметры получаються перетасованы. Я же работаю с параметрами по имени, какая разница в каком порядке они создаються!??
У меня 11 параметров я создаю их так:
...
with Params do
begin
Clear;
CreateParam(ftInteger,"@p1",ptInput);
CreateParam(ftInteger,"@p2",ptInput);
CreateParam(ftInteger,"@p3",ptInput);
...
end;
ParamByName("@p1").AsInteger := XXX;
ParamByName("@p2").AsInteger := YYY;
ParamByName("@p3").AsString := ZZZ;
...
Если переставить, например создание "@p3" на первое место, то при выполнении получиться путаница параметров.
Если это правило(создавать параметры в том же порядке), то я почему-то нигде этого не встречал. DB: Sybase7 ASA


 
Lady D ©   (2002-12-24 12:21) [1]

А Вы не пробовали менять TStoredProc.ParamBindMode?


 
Cheg ©   (2002-12-24 12:27) [2]

Так я использую pbByName, если буду использовать pbByNumbe, смысл тогда в pbByName. И я не могу понять причем тут сама передача параметров от их простого создания??


 
Lady D ©   (2002-12-24 12:37) [3]

Ага, понятно. В процедуре TStoredProc.BindParams перебор параметров происходит в цикле с обращением через Params[i]. Так что последовательность создания имеет значение.


 
Lady D ©   (2002-12-24 12:52) [4]

А может быть ошибка в том, что @p3 создается как ftInteger, а присвоение значения выполняется AsString ?


 
Cheg ©   (2002-12-24 12:52) [5]

Посмотрел...понял. Но мне это кажеться нелогичным. (( Спасибо большое!)


 
Cheg ©   (2002-12-24 12:58) [6]

Нет, это я уже эксперементировал, и код такой вставил



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

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

Наверх




Память: 0.47 MB
Время: 0.024 c
14-62763
Дмитрий К.К.
2002-12-29 19:15
2003.01.20
В сборной мира пополнение!


6-62708
kofman
2002-11-20 21:22
2003.01.20
Как добавит свой пункт в контекстное меню MSIE?


7-62864
KDS
2002-11-04 17:27
2003.01.20
DDR SDRAM


14-62851
_vitek_
2003-01-03 16:28
2003.01.20
FTP


14-62805
Дмитрий К.К.
2003-01-01 07:08
2003.01.20
Именинники 1 января