T-SQL字符串电子邮件格式问题

5
我正在尝试构建一封电子邮件,但遇到了问题。当存储过程运行时,我会收到以下错误消息。
“Msg 14624,Level 16,State 1,Procedure sp_send_dbmail,Line 242 必须指定以下参数之一:“@body,@query,@file_attachments,@subject”。”
我的代码如下,但我已经添加了每个请求的项目。我已经缩小了出现问题的范围。如果我删除连接符“+”,则一切都按预期工作。但我以前使用过连接符号,所以我不确定有什么不同。
DECLARE @RespPeriod varchar(20)
DECLARE @SubjectLine varchar(100)
DECLARE @ContactEmail varChar(100)
DECLARE @AAEAPVSupplierID int
DECLARE @key varchar(50)
DECLARE @formattedURL varchar(100)
DECLARE @emailBody varchar(max)

DECLARE Curs Cursor 
FOR 
    SELECT theID FROM #temptbl

OPEN Curs

FETCH NEXT FROM Curs INTO @theID

WHILE @@FETCH_STATUS = 0
BEGIN
    SELECT * 
    INTO #temptbl 
    FROM tblmainTbl 
    WHERE theID = @theID 

    DECLARE @isComplete Bit = 1

    IF EXISTS (SELECT * FROM #temptbl WHERE Complete = 0)
    BEGIN
        SET @isComplete = 0
    END

    IF @isComplete = 1
    BEGIN
        SET @SubjectLine = 'Testing ' + @RespPeriod + ' Testing.'
        SET @ContactEmail = (SELECT SalesEmail FROM #temptbl WHERE theID = @theID)
        SET @key = (SELECT ResponseKEY FROM #temptbl WHERE theID = @theID)
        SET @formattedURL = 'http://www.something.com/something.aspx?rkey=' + @key
        SET @emailBody = '<html>Dear BlaBlaBla' + @RespPeriod + ' ' +  @formattedURL + '">' + @formattedURL + '</a></html>' 

        EXEC msdb.dbo.sp_send_dbmail 
                    @profile_name = 'SMTPProfile'
                    ,@recipients = @ContactEmail 
                    ,@subject = @SubjectLine
                    ,@body = @emailBody
                    ,@body_format = 'HTML'
    END

    DROP TABLE #temptbl

    FETCH NEXT FROM Curs INTO @theID 
END

CLOSE Curs
DEALLOCATE Curs

从你发布的内容来看,大多数变量都是NULL。当你将它们连接到一个字符串时,结果也会是NULL。我必须问一下,为什么你要在每次循环中创建临时表并删除它?循环和临时表的设置方式有很大问题。 - Sean Lange
1个回答

8

您的代码示例不完整(缺少一些变量的声明)。我的猜测是一个或多个变量值(也许是@RespPeriod?)为NULL,当您在sp_send_dbmail调用中进行变量赋值时,您传递了NULL值。

请记住,字符串+NULL= NULL

在调用sp_send_dbmail之前,在这些语句中插入...

        PRINT '--------------'
        PRINT '@SubjectLine =  ' + ISNULL(@SubjectLine, 'NULL')
        PRINT '@ContactEmail = ' + ISNULL(@ContactEmail, 'NULL')
        PRINT '@key = ' + ISNULL(@key, 'NULL')
        PRINT '@formattedURL = ' + ISNULL(@formattedURL, 'NULL')
        PRINT '@emailBody = ' + ISNULL(@emailBody, 'NULL')
        PRINT '--------------'

如果这是您的问题,那么很快就会变得明显。 如果是这样,请追溯导致整个字符串为空的任何变量的各个部分,直到找到引起该问题的部分。 如果不是,请提供更多代码,以便我们可以在其他地方查找。


像往常一样,我漏掉了一些愚蠢的东西。谢谢你指出来。我从未声明@RespPeriod。 - joerdie
将上述代码立即放置在sp_send_dbmail调用之前。在我的情况下,类似的代码早期检查我的@recipient变量的值是有效的,但在那之后和sp_send_dbmail调用之间它被设置为NULL - Zarepheth

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接