Предоставление доступа к сотням SP? - PullRequest
2 голосов
/ 17 сентября 2008

В Sql Server 2000/2005 у меня есть несколько групп пользователей NT, которым необходимо предоставить доступ к сотням хранимых процедур.

Есть ли хороший способ сделать это?

Ответы [ 2 ]

4 голосов
/ 17 сентября 2008
  • Создание роли на сервере sql.
  • Написать сценарий, который предоставляет эту роль разрешение на использование этих sprocs.
  • Добавьте эти группы пользователей NT к этой роли.
1 голос
/ 17 сентября 2008

Вот скрипт, который я использую для предоставления разрешений многим процедурам:

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

Вы можете изменить выбор, чтобы перейти к более конкретной группе сохраненных процедур.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...