授予数百个 SP 的访问权限?
-
09-06-2019 - |
题
在 Sql Server 2000/2005 中,我有几个 NT 用户组需要被授予对数百个存储过程的访问权限。
有没有一种简单的方法可以做到这一点?
解决方案
这是我用来向许多过程授予权限的脚本:
DECLARE @DB sysname ; set @DB = DB_NAME()
DECLARE @U sysname ; set @U = QUOTENAME('UserID')
DECLARE @ID integer,
@LAST_ID integer,
@NAME varchar(1000),
@SQL varchar(4000)
SET @LAST_ID = 0
WHILE @LAST_ID IS NOT NULL
BEGIN
SELECT @ID = MIN(id)
FROM dbo.sysobjects
WHERE id > @LAST_ID AND type = 'P' AND category = 0
SET @LAST_ID = @ID
-- We have a record so go get the name
IF @ID IS NOT NULL
BEGIN
SELECT @NAME = name
FROM dbo.sysobjects
WHERE id = @ID
-- Build the DCL to do the GRANT
SET @SQL = 'GRANT EXECUTE ON ' + @NAME + ' TO ' + @U
-- Run the SQL Statement you just generated
EXEC master.dbo.xp_execresultset @SQL, @DB
END
END
您可以修改选择以获取更具体的存储过程组。
其他提示
- 在sql server中创建一个角色。
- 编写一个授予该角色许可使用这些Sprocs的脚本。
- 将这些 NT 用户组添加到该角色。
不隶属于 StackOverflow