SQL Server中通用数据库角色权限处理

 

最近和同事在做数据库权限清理的事情,主要是删除一些账号;取消一些账号的较大的权限等,例如,有一些有db_owner权限,我们取消账号的数据库角色db_owner,授予最低要求的相关权限。但是这种工作完全是一个体力活,而且是吃力不讨好,而且推进很慢。另外,为了管理方便和细化,我们又在常用的数据库角色外,新增了6个通用的数据库角色。如下截图所示。

另外,为了减少授权工作量和一些重复的体力活,我们创建了一个作业,每天定期执行一个存储过程db_common_role_grant_rigths,这个存储过程的逻辑如下:

1:遍历所有用户数据库(排除了系统数据库以及一些特殊数据库),发现该数据库不存在这些通用数据库角色,那么就创建相关数据库角色。

2:遍历所有用户数据库,为相关数据库角色授权,例如,如果发现某个新增的存储过程,没有授权给db_procedure_execute数据库角色。那么就执行授权操作。

当然目前还在测试、应用阶段,以后会根据具体相关需求,不断完善相关功能。

  1. --==================================================================================================================

  1. --        ScriptName            :            db_common_role_grant_rigths.sql

  1. --        Author                :            潇湘隐者   

  1. --        CreateDate            :            2018-09-13

  1. --        Description           :            创建数据库角色db_procedure_execute等,并授予相关权限给角色。

  1. --        Note                  :           

  1. /******************************************************************************************************************

  1.         Parameters              :                                    参数说明

  1. ********************************************************************************************************************

  1.              @RoleName          :            角色名

  1. ********************************************************************************************************************

  1.    Modified Date    Modified User     Version                 Modified Reason

  1. ********************************************************************************************************************

  1.     2018-09-12       潇湘隐者         V01.00.00      新建该脚本。

  1.     2018-09-12       潇湘隐者         V01.00.01      注意@@ROWCOUNT的生效范围;解决循环逻辑问题。

  1.     2018-09-26       潇湘隐者         V01.00.02      修正类型为FT(CLR_TABLE_VALUED_FUNCTION)的函数问题。程序集 (CLR) 表值函数

  1. *******************************************************************************************************************/

  1. --===================================================================================================================

  1. USE YourSQLDba;

  1. GO

  1.  

  1.  

  1. IF EXISTS (SELECT 1 FROM sys.procedures WHERE type='P' AND name='db_common_role_grant_rigths')

  1. BEGIN

  1.     DROP PROCEDURE Maint.db_common_role_grant_rigths;

  1. END

  1. GO

  1.  

  1. CREATE PROCEDURE Maint.db_common_role_grant_rigths

  1. AS

  1. BEGIN

  1.  

  1. DECLARE @database_id    INT;

  1. DECLARE @database_name  sysname;

  1. DECLARE @cmdText        NVARCHAR(MAX);

  1. DECLARE @prc_text        NVARCHAR(MAX);

  1. DECLARE @RowIndex        INT;

  1.  

  1. IF OBJECT_ID('TempDB.dbo.#databases') IS NOT NULL

  1.     DROP TABLE dbo.#databases;

  1.  

  1. CREATE TABLE #databases

  1. (

  1.     database_id        INT,

  1.     database_name   sysname

  1. )

  1.  

  1. IF OBJECT_ID('TempDB.dbo.#sql_text') IS NOT NULL

  1.     DROP TABLE dbo.#sql_text;

  1.  

  1.  

  1. CREATE TABLE #sql_text

  1. (

  1.     sql_id      INT IDENTITY(1,1),

  1.     sql_cmd     NVARCHAR(MAX)

  1. )

  1.  

  1. INSERT  INTO #databases

  1. SELECT  database_id ,

  1.         name

  1. FROM    sys.databases

  1. WHERE   name NOT IN ( 'master', 'tempdb', 'model', 'msdb',

  1.                         'distribution', 'ReportServer',

  1.                         'ReportServerTempDB', 'YourSQLDba' )

  1.         AND state = 0; --state_desc=ONLINE

  1.  

  1.  

  1. --开始循环每一个用户数据库(排除了上面相关数据库)

  1. WHILE 1= 1

  1. BEGIN

  1.  

  1.  

  1.     SELECT TOP 1 @database_name= database_name  

  1.     FROM #databases

  1.     ORDER BY database_id;

  1.  

  1.    

  1.     IF @@ROWCOUNT =0

  1.         BREAK;

  1.  

  1.     --PRINT(@database_name);

  1.  

  1.     -- SP_EXECUTESQL 中切换数据库不能当参数传入。

  1.  

  1.     --创建数据库角色db_procedure_execute

  1.     SET @cmdText =  'USE ' + @database_name + ';' +CHAR(10)

  1.  

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_procedure_execute'')

  1.                         BEGIN

  1.                             CREATE ROLE [db_procedure_execute] AUTHORIZATION [dbo];

  1.                         END ' + CHAR(10);

  1.  

  1.  

  1.  

  1.     --创建数据库角色db_function_execute

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_function_execute'')

  1.                         BEGIN

  1.                             CREATE ROLE [db_function_execute] AUTHORIZATION [dbo];

  1.                         END' + CHAR(10);

  1.  

  1.  

  1.     --创建数据库角色db_view_table_definition

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_table_definition'')

  1.                         BEGIN

  1.                             CREATE ROLE [db_view_table_definition] AUTHORIZATION [dbo];

  1.                         END ' + CHAR(10);

  1.  

  1.     --创建数据库角色db_view_view_definition

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_view_definition'')

  1.                          BEGIN

  1.                             CREATE ROLE [db_view_view_definition] AUTHORIZATION [dbo];

  1.                          END ' + CHAR(10);

  1.  

  1.     --创建数据库角色db_view_procedure_definition

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_procedure_definition'')

  1.                         BEGIN

  1.                             CREATE ROLE [db_view_procedure_definition] AUTHORIZATION [dbo];

  1.                         END ' + CHAR(10);

  1.  

  1.      --创建数据库角色db_view_function_definition

  1.     SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_function_definition'')

  1.                         BEGIN

  1.                             CREATE ROLE [db_view_function_definition] AUTHORIZATION [dbo];

  1.                         END ' + CHAR(10);

  1.  

  1.     --PRINT @cmdText;

  1.     -- EXECUTE SP_EXECUTESQL @cmdText;

  1.     EXECUTE (@cmdText);

  1.  

  1.  

  1.    

  1.     --给角色db_procedure_execute授权

  1.    

  1.     SET @cmdText ='USE ' + QUOTENAME(@database_name) + ';' 

  1.  

  1.     SET @cmdText +='INSERT INTO #sql_text(sql_cmd)

  1.                     SELECT  ''GRANT EXECUTE  ON '' + SCHEMA_NAME(schema_id) + ''.''

  1.                        + QUOTENAME(name) + '' TO db_procedure_execute;''

  1.                        FROM   sys.procedures s

  1.                        WHERE     NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_procedure_execute''))';

  1.      EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.  

  1.  

  1.      --给角色db_function_execute(标量函数授权)

  1.  

  1.      SET @cmdText ='USE ' + QUOTENAME(@database_name) + ';' 

  1.  

  1.      SET @cmdText += 'INSERT INTO #sql_text(sql_cmd)

  1.                      SELECT  ''GRANT EXEC ON '' + SCHEMA_NAME(schema_id) + ''.'' + QUOTENAME(name) + '' TO  db_function_execute; '' 

  1.                      FROM    sys.all_objects s

  1.                      WHERE  SCHEMA_NAME(schema_id) NOT IN (''sys'', ''INFORMATION_SCHEMA'') 

  1.                         AND    NOT EXISTS ( SELECT 1

  1.                                                 FROM   sys.database_permissions p

  1.                                                 WHERE  p.major_id = s.object_id

  1.                                                 AND  p.grantee_principal_id =USER_ID(''db_function_execute'') )

  1.                                                 AND ( s.[type] = ''FN''

  1.                                                         OR s.[type] = ''AF''

  1.                                                         OR s.[type] = ''FS''

  1.                                                         --OR s.[type] = ''FT''

  1.                                                     ) ;'

  1.         EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.  

  1.       --给角色db_function_execute(表值函数授权)

  1.       SET @cmdText ='USE ' + @database_name + ';'

  1.  

  1.       SET @cmdText += 'INSERT INTO #sql_text(sql_cmd)

  1.                        SELECT  ''GRANT SELECT ON '' + SCHEMA_NAME(schema_id) + ''.'' + QUOTENAME(name) + '' TO  db_function_execute;''

  1.                        FROM    sys.all_objects s

  1.                        WHERE  SCHEMA_NAME(schema_id) NOT IN (''sys'', ''INFORMATION_SCHEMA'')  

  1.                           AND    NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_function_execute''))

  1.                                   AND ( s.[type] = ''TF''

  1.                                         OR s.[type] = ''IF''

  1.                             ) ;    '

  1.  

  1.       EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.       --查看存储过程定义授权

  1.       SET @cmdText ='USE ' + @database_name + ';'

  1.  

  1.       SET @cmdText +=' INSERT INTO #sql_text(sql_cmd)

  1.                        SELECT  ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''

  1.                        + QUOTENAME(name) + '' TO db_view_procedure_definition;''

  1.                        FROM   sys.procedures s

  1.                        WHERE     NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_view_procedure_definition''))'

  1.  

  1.        EXECUTE(@cmdText);

  1.  

  1.        --查看函数定义的授权

  1.        SET @cmdText ='USE ' + @database_name + ';'

  1.  

  1.        SELECT   @cmdText += 'INSERT INTO #sql_text(sql_cmd)

  1.                             SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''

  1.                             + QUOTENAME(name) + '' TO  db_view_function_definition;''

  1.                             FROM sys.objects s

  1.                             WHERE type_desc IN (''SQL_SCALAR_FUNCTION'', ''SQL_TABLE_VALUED_FUNCTION'',

  1.                                  ''AGGREGATE_FUNCTION'' )

  1.                                     AND    NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_view_function_definition''))';

  1.  

  1.         EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.        --查看表定义的授权

  1.        SET @cmdText ='USE ' + @database_name + ';'

  1.  

  1.        SET @cmdText +='INSERT INTO #sql_text(sql_cmd)

  1.                       SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''

  1.                       + QUOTENAME(name) + '' TO db_view_table_definition ;''

  1.                       FROM  sys.tables s

  1.                       WHERE  NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_view_table_definition''))';

  1.    

  1.        EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.        --查看视图定义的授权

  1.        SET @cmdText ='USE ' + @database_name + ';'

  1.  

  1.        SET @cmdText +='INSERT INTO #sql_text(sql_cmd)

  1.                       SELECT  ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''

  1.                              + QUOTENAME(name) + '' TO db_view_view_definition; ''

  1.                       FROM    sys.views s

  1.                       WHERE  NOT EXISTS ( SELECT 1

  1.                                              FROM   sys.database_permissions p

  1.                                              WHERE  p.major_id = s.object_id

  1.                                                     AND  p.grantee_principal_id = USER_ID(''db_view_view_definition''))';

  1.    

  1.        EXECUTE SP_EXECUTESQL @cmdText;

  1.  

  1.  

  1.  

  1.         WHILE 1= 1

  1.         BEGIN

  1.            

  1.            

  1.             SELECT TOP 1 @RowIndex=sql_id, @cmdText =  'USE ' + @database_name + '; '+ sql_cmd FROM #sql_text ORDER BY sql_id;

  1.  

  1.             IF @@ROWCOUNT =0

  1.                 BREAK;

  1.  

  1.        

  1.             PRINT(@cmdText);

  1.             EXECUTE(@cmdText);

  1.  

  1.             DELETE FROM #sql_text WHERE sql_id =@RowIndex

  1.  

  1.  

  1.         END

  1.        

  1.            

  1.      DELETE FROM #databases WHERE database_name=@database_name;

  1. END

  1.     

  1.      DROP TABLE #databases;

  1.      DROP TABLE #sql_text;

  1.  

  1. END

  1.  

  1.  

  1.  

  1.  

  1.  

SQL Server中通用数据库角色权限处理的更多相关文章

  1. SQL Server中通用数据库角色权限的处理详解

    SQL Server中通用数据库角色权限的处理详解 前言 安全性是所有数据库管理系统的一个重要特征.理解安全性问题是理解数据库管理系统安全性机制的前提. 最近和同事在做数据库权限清理的事情,主要是删除 ...

  2. SQL Server中查询数据库及表的信息语句

    /* -- 本文件主要是汇总了 Microsoft SQL Server 中有关数据库与表的相关信息查询语句. -- 下面的查询语句中一般给出两种查询方法, -- A方法访问系统表,适应于SQL 20 ...

  3. SQL Server 中为何拥有db_owner权限的账号删除不掉数据库

    今天在公司的SQL Server服务器上,使用了一个只有public和dbcreator角色的账号"user1"在SMSS中去删除一个数据库,但是死活报错说没有权限,报错如下: D ...

  4. 解决SQL Server中无管理员账户权限问题

    遇到忘记SQL Server管理员账户密码或管理员账户被意外删除的情况,如何在SQL Server中添加一个新的管理员账户?按一下步骤操作可添加一个windows账户到SQL Server中,并分配数 ...

  5. SQL Server:查看数据库用户权限(SQL 2005)

    1. 查看 SQL 2005 用户所属数据库角色 use yourdb go select DbRole = g.name, MemberName = u.name, MemberSID = u.si ...

  6. 服务器重启可能会导致SQL Server中部分数据库变为single user mode

    今天检查公司生产服务器的SQL Server数据库,惊讶的发现有三个生产数据库变为了single user mode.奇怪的是没有任何人和程序执行过SQL语句将这三个数据库设置为single user ...

  7. 转 在SQL Server中创建用户角色及授权(使用SQL语句)

     目录 要想成功访问 SQL Server 数据库中的数据 我们需要两个方面的授权 完整的代码示例 使用存储过程来完成用户创建 实例 要想成功访问 SQL Server 数据库中的数据, 我们需要两个 ...

  8. 在SQL Server中创建用户角色及授权

    参考文献 http://database.51cto.com/art/201009/224075.htm 正文 要想成功访问 SQL Server 数据库中的数据, 我们需要两个方面的授权: 获得准许 ...

  9. 【转】在SQL Server中创建用户角色及授权(使用SQL语句)

    1. 首先在 SQL Server 服务器级别,创建登陆帐户(create login) --创建登陆帐户(create login) create login dba with password=' ...

随机推荐

  1. 如何在mpvue下收集小程序的formId

    什么是formId formId是小程序可以向用户发送模板消息的通行证,简单而言,你只有获取到formId,把它交给后台,后台同学才能向用户发送通知消息,而这个通行证的有效期只有七天.这是微信为了防止 ...

  2. 浅谈Unity3D 骨骼动画

    转载请标明出处http://www.cnblogs.com/zblade/ 最近研究了一下游戏中模型的骨骼动画的原理,做一个学习笔记,便于大家共同学习探讨. ps:最近改bug改的要死要活,博客写的吭 ...

  3. Google的java工具类Guava

    前言 google开发java项目肯定也不想重复造轮子,所以肯定也有工具类,就是它了:Guava 我将举例几个实际的例子,发挥这个工具类好用的功能.更多的方法和功能,还有内部的实现可以直接参考http ...

  4. Java实现敏感词过滤 - DFA算法

    Java实现DFA算法进行敏感词过滤 封装工具类如下: 使用前需对敏感词库进行初始化: SensitiveWordUtil.init(sensitiveWordSet); package cn.swf ...

  5. Hibernate学习(六)———— cascade(级联)和inverse关系详解

    序言 写这篇文章之前,自己也查了很多的资料来搞清楚这两者的关系和各自所做的事情,但是百度一搜,大多数博文感觉说的云里雾里,可能博主自己清楚是怎么一回事,但是给一个不懂的人或者一知半解的人看的话,别人也 ...

  6. Android studio 下 JNI 开发实例

    在AS中进行 NDK 开发之前,我们先来简单的介绍几个大家都容易搞懵的概念: 到底什么是JNI,什么是NDK? 何为“交叉编译”? 先看什么是 JNI?JNI 的全称就是 Java Native In ...

  7. Java虚拟机——类的结构与加载

    1.为什么Java可以跨平台 因为有java虚拟机,跨平台是因为字节码即class文件具有平台无关性,java代码会经过java虚拟机转换为字节码 2.class文件的结构 class文件主要是以8位 ...

  8. 使用xhprof会在nginx下报502 Bad Gateway错误

    使用xhprof会在nginx下报502 Bad Gateway错误 xhprof_enable()xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMO ...

  9. Java 泛型中的PECS原则

    在泛型编程时,使用部分限定的形参时,<? super T>和<? extends T>的使用场景容易混淆,PECS原则可以帮助我们很好记住它们: 生产者(Producer)使用 ...

  10. java过滤器(简化认证)

    最近在看过滤器,刚刚实现了过滤器的简化认证功能: 使用过滤器简化认证: 在Web应用程序中,过滤器的一个关键用例是保护应用程序不被未授权的用户访问.为跨国部件公司开发的客户支持应用程序使用了一种非常原 ...