sp_send_dbmail失败并附件

时间:2018-06-14 13:39:50

标签: sql-server sql-server-2012

我需要发送带有文件附件的电子邮件。附件必须来自图像类型数据字段。在查询窗口和存储过程中运行以下代码时,不会发送任何电子邮件。在查询窗口中,它只是说'命令已成功完成'但没有电子邮件。

EXEC  msdb.dbo.sp_send_dbmail @recipients = 'xx@xx.com',
    @subject = 'test',
    @execute_query_database = 'myDB',
    @body = 'test',
    @body_format = 'HTML', 
    @profile_name = 'myProfile',
    @append_query_error = 1,
    @query = 'Select docData from [myDB].[dbo].[Documents] Where id = 1',
    @query_result_header = 0,
    @attach_query_result_as_file = 1,
    @query_attachment_filename = 'Test.doc',
    @exclude_query_output = 1,
    @query_no_truncate = 1;

当我删除@query时发送电子邮件:

EXEC  msdb.dbo.sp_send_dbmail @recipients = 'xx@xx.com',
    @subject = 'test',
    @execute_query_database = 'myDB',
    @body = 'test',
    @body_format = 'HTML', 
    @profile_name = 'myProfile';

但是我需要附件代码才能工作。任何帮助将不胜感激。

3 个答案:

答案 0 :(得分:5)

评论太久了。

TS2688: cannot find file definition for node更改为@exclude_query_output = 0。这可能会打印正在发生的消息(错误消息)。

在您的示例中,我能够解决错误:

  

无法初始化sqlcmd库,错误号为-2147024809。

我得到了,我希望您可以将@exclude_query_output = 1更改为@query_result_header = 0。我不确定为什么缺少标题会导致它失败,但它会将其修复到我的开发框中。

答案 1 :(得分:1)

就我而言,不是这样:

SET @Send_Query_Text = 
'SELECT Message_Text FROM DataMonitoring.Alert_Message WHERE Message_Setup_Key =' + CAST( @Message_Setup_Key AS VARCHAR(10)) + ' AND Mailing_GUID = ''' + CAST(@Mailing_GUID AS VARCHAR(36))+'''';

我应该这样做:

SET @Send_Query_Text = 
    'SELECT Message_Text FROM Staging_Area.DataMonitoring.Alert_Message WHERE Message_Setup_Key =' + CAST( @Message_Setup_Key AS VARCHAR(10)) + ' AND Mailing_GUID = ''' + CAST(@Mailing_GUID AS VARCHAR(36))+'''';

如您所见,查询应该包含数据库,否则它将无法工作

答案 2 :(得分:0)

我遇到了同样的问题,但是发现的解决方案都没有帮助。最终MSSQLTips引导我朝着正确的方向前进。运行探查器时,出现以下错误消息:

  

无法获取有关Windows NT组/用户的信息   “ DOMAIN \ user”,错误代码0x5

检查Windows安全事件日志中是否存在审计失败,我终于找到了原因:

  

指定帐户的密码已过期。

与SQL Server和SQL Server Agent一起运行的活动目录帐户已设置为允许密码过期。在AD帐户上禁用密码有效,即可立即解决此问题。