首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >附件sp_send_dbmail失败

附件sp_send_dbmail失败
EN

Stack Overflow用户
提问于 2018-06-14 13:39:50
回答 5查看 41.2K关注 0票数 7

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

代码语言:javascript
复制
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时,电子邮件将发送:

代码语言:javascript
复制
EXEC  msdb.dbo.sp_send_dbmail @recipients = 'xx@xx.com',
    @subject = 'test',
    @execute_query_database = 'myDB',
    @body = 'test',
    @body_format = 'HTML', 
    @profile_name = 'myProfile';

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

EN

回答 5

Stack Overflow用户

回答已采纳

发布于 2018-06-14 15:40:28

时间太长了,不能发表评论。

@exclude_query_output = 0更改为@exclude_query_output = 1。这可能会打印一条关于正在发生的事情的消息(错误消息)。

在您的示例中,我能够避免错误:

未能用错误号-2147024809初始化sqlcmd库。

我得到了这一点,我希望您可以通过将@query_result_header = 0更改为@query_result_header = 1来获得。我不知道为什么缺少标题会导致它失败,但它将其修复在我的文本框上。

票数 11
EN

Stack Overflow用户

发布于 2020-09-23 12:28:05

在我的例子中,而不是这样:

代码语言:javascript
复制
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))+'''';

我应该这么做的:

代码语言:javascript
复制
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))+'''';

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

票数 3
EN

Stack Overflow用户

发布于 2019-10-09 11:05:08

我也有同样的问题,但我找到的解决方案都没有帮助。最后,MSSQLTips把我引向了正确的方向。运行分析器时,我收到以下错误消息:

无法获得有关Windows组/用户'DOMAIN\user‘的信息,错误代码为0x5

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

指定帐户的密码已过期。

已设置运行Server和Server代理的活动目录帐户以允许密码过期。禁用AD帐户上的密码过期将立即解决此问题。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50858900

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档