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

Вниз

Не пойму как возвратить результат запроса   Найти похожие ветки 

 
dreamse   (2005-02-08 09:49) [0]

В общем код процедуры SQL такой :

CREATE procedure summaperioda (@numberperiod int)
as
select sum(cast(summa as money)) from Tab_jurnalseansov
where period = @numberperiod
GO

я передаю туда параметр @numberperiod и в соответствии с ним идёт подсчёт данных по столбцу summa

Код Delphi такой :

Ado_proc_kassa.CommandText:="summaperioda";
Ado_proc_kassa.Parameters.Refresh;
Ado_proc_kassa.Parameters.ParamByName("@numberperiod").Value:=10;
Ado_proc_kassa.Execute;

Вопрос как в переменную вернуть значение полученное в результате выполенения процедуры SQL сервера ?


 
Rob   (2005-02-08 10:07) [1]

CREATE procedure summaperioda (@numberperiod int)
as
select sum(cast(summa as money)) my_sum from Tab_jurnalseansov
where period = @numberperiod
GO

На клиенте что-то типа:

var My_Sum: currency;

Query1.SQL.Add("exec summaperioda и т.д.
Query1.Open;

My_Sum:=Query1.FieldByName("my_sum ").AsCurrency;


 
MOA ©   (2005-02-08 10:12) [2]

Результат вернётся в виде рекордсета.
Т.е. вызывайте процедуру из компонента, возвращающего рекордсет (т.е. наследника DataSet, (но не TADOCommand) - а значит, и не Execute, а Open (или Active=True) (exec владелец.Имя_процедуры).
PS. Если у вас MSSQL2000 то, ПМСМ, удобнее подобные вещи выполнять в виде не процедур, а функций.
Удачи!


 
dreamse   (2005-02-08 10:48) [3]

Спасибо !



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

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

Наверх




Память: 0.47 MB
Время: 0.065 c
3-1107787186
Anunimus
2005-02-07 17:39
2005.03.06
Interbase параметры по умолчанию


11-1090184979
Dmitrii
2004-07-19 01:09
2005.03.06
PaintBox на Panel и


14-1108508124
GanibalLector
2005-02-16 01:55
2005.03.06
Дайджесты форумов


14-1108477273
Prohodil Mimo
2005-02-15 17:21
2005.03.06
чем округлить 690.005 что бы получилось 690.01, а не 690.00 ?


1-1108625807
Niki
2005-02-17 10:36
2005.03.06
StringGrid