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

Вниз

output-параметры в рекурсивных выборках   Найти похожие ветки 

 
Ega23 ©   (2005-08-10 16:49) [0]

Есть такая простенькая процедура:

if exists (select * from sysobjects where id = object_id(N"[S_TempProc]") and OBJECTPROPERTY(id, N"IsProcedure") = 1)
drop procedure [S_TempProc]
GO
CREATE PROCEDURE S_TempProc
@Count int=0,
@OutMess varchar(2000) ="" output

As
Declare @Result int;

Select @Result=@Count+1;

Select @OutMess=@OutMess+";"+Cast(@Count as varchar(3));

if @Count<5
exec @Result=S_TempProc @Count=@Result, @OutMess=@OutMess output  
Return(@Result);
go



Есть такой простенький скрипт её вызова:

Declare
 @ss varchar(2000)

exec S_TempProc @Count=0, @OutMess=@ss output;
select X=@ss


Почему на выходе всё время NULL???


 
MOA ©   (2005-08-10 17:08) [1]

Любая операция с NULL даст NULL. В том числе и
@OutMess=@OutMess+";"+Cast(@Count as varchar(3))

Т.е. при вызове параметру @OutMess нужно присвоить хотя бы пустую строку:
Declare
@ss varchar(2000)
SET @ss=""

Удачи!


 
Ega23 ©   (2005-08-10 17:13) [2]

Оп-па.... Как же это я так проглядел-то!!!!
Пора домой...
Спасибо!



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

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

Наверх




Память: 0.47 MB
Время: 0.044 c
1-1125391752
nikolas
2005-08-30 12:49
2005.09.25
Пошаговое тестирование DLL


1-1125436052
SergProger
2005-08-31 01:07
2005.09.25
Перетаскивание формы


4-1122545484
ingine
2005-07-28 14:11
2005.09.25
Проблема с потоками


4-1122368758
Чапаев
2005-07-26 13:05
2005.09.25
LPT-порт. Чтение/запись.


4-1123098743
ZLOFENIX
2005-08-03 23:52
2005.09.25
помогите с ПРИМЕРАМИ