0

我有一个存储过程,其中包含一个游标,用于循环遍历 SQL 记录并填充我稍后将用作电子邮件文本的字符串。我正在尝试将其打印出来进行验证,然后才能继续进行,但它似乎没有填充字符串。这是我在 SQL Server 2005 中的存储过程。

CREATE PROCEDURE [dbo].[spBody] 
AS
DECLARE @MyCursor CURSOR
DECLARE @emailBody nvarchar(max)
DECLARE @statusName nvarchar(max)
DECLARE @deptCode nvarchar(max)
DECLARE @instructors nvarchar(max)
DECLARE @meetingTime nvarchar(max)

SET @MyCursor = CURSOR FAST_FORWARD For
Select StatusName, DeptCode, Instructors, Description from MyTable where StatusID = (select CAST(value AS INT) from Table2 where ConfigOption = 'RequiredStatus')

Open @MyCursor
FETCH NEXT FROM @MyCursor INTO @statusName, @deptCode, @instructors, @meetingTime


WHILE @@FETCH_STATUS = 0

BEGIN
 SET @emailBody = @emailBody + @statusName + ' ' + @deptCode + ' ' + @instructors + ' ' + @meetingTime 
 FETCH NEXT FROM @MyCursor INTO @statusName, @deptCode, @instructors, @meetingTime

END
CLOSE @MyCursor
Print @emailBody

DEALLOCATE @MyCursor 
4

2 回答 2

6

这是因为@emailBody 以 NULL 开头,任何与 NULL 的串联默认都会产生 NULL。做一个

SET @emailBody = '';

在脚本的开头。

此外,强烈考虑SET NOCOUNT ON;在存储过程的顶部添加一条语句——没有 NOCOUNT ON 会大大减慢 proc 的执行速度。

于 2011-01-07T20:11:40.977 回答
0

为什么你需要这个字符串 concat 的游标。不会出现以下查询后缀

DECLARE @emailBody nvarchar(max) 

Set @emailBody = ''

Select @emailBody = @emailBody + StatusName + ' ' + DeptCode + ' ' + Instructors + ' ' + [Description] from MyTable where StatusID = (select CAST(value AS INT) from Table2 where ConfigOption = 'RequiredStatus')

Print @emailBody
于 2011-01-07T20:25:05.527 回答