sql-server – 授予执行存储过程的角色

前端之家收集整理的这篇文章主要介绍了sql-server – 授予执行存储过程的角色前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个代理用户,我正在尝试添加到可以执行所有存储过程的角色.使用其他StackOverflow帖子,我已经能够将这个脚本放在一起
USE abc

Create ROLE db_exec
go

GRANT EXECUTE TO db_exec
go

EXEC sp_addrolemember 'db_exec','abc_user'
go

当我尝试运行我的存储过程时,根据我的错误处理,我仍然会收到此错误.

The EXECUTE permission was denied on the object ‘sp_OACreate’,database ‘mssqlsystemresource’,schema ‘sys’.

如何让abc_user执行sp_OACreate?

解决方法

除了处于sysadmin角色之外,还需要在master数据库上授予执行权限,这些进程实际驻留在这些数据库
use master
go

grant exec on sp_OACreate to abc_user
GO

运行之后,您可以使用以下内容验证您是否有权执行该过程

SELECT * 
FROM master.sys.database_permissions [dp] 
JOIN master.sys.system_objects [so] ON dp.major_id = so.object_id
JOIN master.sys.sysusers [usr] ON 
     usr.uid = dp.grantee_principal_id AND usr.name = 'abc_user'
WHERE permission_name = 'EXECUTE' AND so.name = 'sp_OACreate'

猜你在找的MsSQL相关文章