杯中水

导航

 

 

新的账号有使用表Tigger调用Database Mail发送邮件时报错:Msg 229, Level 14, State 5, Procedure sp_send_dbmail, Line 1,EXECUTE permission denied on object 'sp_send_dbmail', database 'msdb', schema 'dbo'.

这是因为,当前 SQL Server 登陆帐户(login),在 msdb 数据库中没有发送数据库邮件的权限,需要加入 msdb 数据库用户,并通过加入 sp_addrolemember 角色赋予权限。

假设该SQL Server 登陆帐户名字为 “dba”

use msdb

go 

create user dba for login dba

go

 exec dbo.sp_addrolemember @rolename   = 'DatabaseMailUserRole',

                          @membername = 'dba'

go

 

此时,再次发送数据库邮件,仍可能有错误:

Msg 14607, Level 16, State 1, Procedure sp_send_dbmail, Line 119

profile name is not valid

虽然,数据库用户 “dba” 已经在 msdb 中拥有发送邮件的权限了,但这还不够,他还需要有使用 profile:“dba_profile” 的权限。

 

use msdb

go

exec sysmail_add_principalprofile_sp  @principal_name = 'dba'

                                     ,@profile_name   = 'dba_profile'

                                     ,@is_default     = 1

 

这样就可以使用新账号调用Database Mail发送邮件了。

posted on 2012-11-22 16:23  杯中水_F  阅读(1320)  评论(0编辑  收藏  举报