我正在执行一个SP,它动态地构建从多个数据库收集的数据的全局临时表。此SP的末尾是下面这行代码:
Exec msdb.dbo.sp_send_dbmail
@profile_name = @dbmailProfileName,
@recipients = @emailRecipents,
@subject = @subject,
@body = @body,
@query = 'Select * From tempdb..##MyTempTable'当我手动执行此SP时,它工作得很好,但是,当我让我的Server Agent Job运行它时,它会失败,并显示以下错误:
Message
Executed as user: WORKGROUP\MyServer2016$. Failed to initialize sqlcmd library with error number -2147467259. [SQLSTATE 42000] (Error 22050) Failed to initialize sqlcmd library with error number -2147467259. [SQLSTATE 42000] (Error 22050). The step failed.注释掉SP的@query部分可以很好地工作,但这是无用的,因为我需要通过电子邮件发送数据。
发布于 2017-02-28 23:06:14
我知道这是某种安全问题,但我缺乏DBA技能。然而,我发现了一种变通的解决方案,它并不完全是我想要的,但它是有效的。
编辑作业步骤,以便在我的工作登录名中包含执行方式:
Execute As Login='MyUser'
GO
exec DBNAME.dbo.SPNAME
GO
Revert
GO由于MyUser可以手动运行此程序,因此我以登录身份执行。
发布于 2019-03-13 00:02:30
然后我得到了同样的错误,在无数次尝试和错误尝试之后,又出现了另一个错误:
The EXECUTE permission was denied on the object 'xp_sysmail_format_query',
database 'mssqlsystemresource', schema 'sys'.我将该用户添加到master数据库中的public角色,然后为该用户添加了以下权限:
grant execute on xp_sysmail_format_query to [myuser]数据库邮件似乎依赖于这个存储的进程。这样做之后,电子邮件作业就可以正常工作了。注意:我以指定用户的身份运行作业。
发布于 2017-02-28 04:28:38
您是否尝试过使用@execute_query_database参数?如果此操作不起作用,请尝试将Sql Server代理帐户作为sysadmin添加到Sql Server
https://stackoverflow.com/questions/42494500
复制相似问题