In SQL Server 2005, is there an easy way to “copy” permissions on an object from one user/role to another?

后端 未结 2 832
无人及你
无人及你 2021-01-15 06:46

I asked another question about roles and permissions, which mostly served to reveal my ignorance. One of the other outcomes was the advice that one should generally stay aw

相关标签:
2条回答
  • 2021-01-15 07:08

    Working from memory (no SQL on my gaming 'pooter), you can use sys.database_permissions

    Run this and paste the results into a new query.

    Edit, Jan 2012. Added OBJECT_SCHEMA_NAME.
    You may need to pimp it to support schemas (dbo.) by joining onto sys.objects

    SET NOCOUNT ON;
    DECLARE @NewRole varchar(100), @SourceRole varchar(100);
    
    -- Change as needed
    SELECT @SourceRole = 'Giver', @NewRole = 'Taker';
    
    SELECT
        state_desc + ' ' + 
              permission_name + ' ON ' + 
              OBJECT_SCHEMA_NAME(major_id) + '.' + OBJECT_NAME(major_id) +
              ' TO ' + @NewRole
    FROM
        sys.database_permissions
    WHERE
        grantee_principal_id = DATABASE_PRINCIPAL_ID(@SourceRole) 
        AND
        -- 0 = DB,  1 = object/column, 3 = schema. 1 is normally enough
        class <= 3;
    
    0 讨论(0)
  • 2021-01-15 07:17

    The idea of having a role is that you only need to setup the permissions once. You can then assign users, or groups of users to that role.

    It's also possible to nest roles, so that a role can contain other roles.

    Not sure if its best practice, but it makes sense that if you have a complex set of permissions, with groups of users that need access to multiple applications you go something like:

    NT User -> NT Security Group -> SQL Server Role -> SQL Server Role A, Role B ...

    0 讨论(0)
提交回复
热议问题