SQL Server中通用数据库角色权限处理
SQL Server中通用数据库角色权限处理
最近和同事在做数据库权限清理的事情,主要是删除一些账号;取消一些账号的较大的权限等,例如,有一些有db_owner权限,我们取消账号的数据库角色db_owner,授予最低要求的相关权限。但是这种工作完全是一个体力活,而且是吃力不讨好,而且推进很慢。另外,为了管理方便和细化,我们又在常用的数据库角色外,新增了6个通用的数据库角色。如下截图所示。
另外,为了减少授权工作量和一些重复的体力活,我们创建了一个作业,每天定期执行一个存储过程db_common_role_grant_rigths,这个存储过程的逻辑如下:
1:遍历所有用户数据库(排除了系统数据库以及一些特殊数据库),发现该数据库不存在这些通用数据库角色,那么就创建相关数据库角色。
2:遍历所有用户数据库,为相关数据库角色授权,例如,如果发现某个新增的存储过程,没有授权给db_procedure_execute数据库角色。那么就执行授权操作。
当然目前还在测试、应用阶段,以后会根据具体相关需求,不断完善相关功能。
- --==================================================================================================================
- -- ScriptName : db_common_role_grant_rigths.sql
- -- Author : 潇湘隐者
- -- CreateDate : 2018-09-13
- -- Description : 创建数据库角色db_procedure_execute等,并授予相关权限给角色。
- -- Note :
- /******************************************************************************************************************
- Parameters : 参数说明
- ********************************************************************************************************************
- @RoleName : 角色名
- ********************************************************************************************************************
- Modified Date Modified User Version Modified Reason
- ********************************************************************************************************************
- 2018-09-12 潇湘隐者 V01.00.00 新建该脚本。
- 2018-09-12 潇湘隐者 V01.00.01 注意@@ROWCOUNT的生效范围;解决循环逻辑问题。
- 2018-09-26 潇湘隐者 V01.00.02 修正类型为FT(CLR_TABLE_VALUED_FUNCTION)的函数问题。程序集 (CLR) 表值函数
- *******************************************************************************************************************/
- --===================================================================================================================
- USE YourSQLDba;
- GO
- IF EXISTS (SELECT 1 FROM sys.procedures WHERE type='P' AND name='db_common_role_grant_rigths')
- BEGIN
- DROP PROCEDURE Maint.db_common_role_grant_rigths;
- END
- GO
- CREATE PROCEDURE Maint.db_common_role_grant_rigths
- AS
- BEGIN
- DECLARE @database_id INT;
- DECLARE @database_name sysname;
- DECLARE @cmdText NVARCHAR(MAX);
- DECLARE @prc_text NVARCHAR(MAX);
- DECLARE @RowIndex INT;
- IF OBJECT_ID('TempDB.dbo.#databases') IS NOT NULL
- DROP TABLE dbo.#databases;
- CREATE TABLE #databases
- (
- database_id INT,
- database_name sysname
- )
- IF OBJECT_ID('TempDB.dbo.#sql_text') IS NOT NULL
- DROP TABLE dbo.#sql_text;
- CREATE TABLE #sql_text
- (
- sql_id INT IDENTITY(1,1),
- sql_cmd NVARCHAR(MAX)
- )
- INSERT INTO #databases
- SELECT database_id ,
- name
- FROM sys.databases
- WHERE name NOT IN ( 'master', 'tempdb', 'model', 'msdb',
- 'distribution', 'ReportServer',
- 'ReportServerTempDB', 'YourSQLDba' )
- AND state = 0; --state_desc=ONLINE
- --开始循环每一个用户数据库(排除了上面相关数据库)
- WHILE 1= 1
- BEGIN
- SELECT TOP 1 @database_name= database_name
- FROM #databases
- ORDER BY database_id;
- IF @@ROWCOUNT =0
- BREAK;
- --PRINT(@database_name);
- -- SP_EXECUTESQL 中切换数据库不能当参数传入。
- --创建数据库角色db_procedure_execute
- SET @cmdText = 'USE ' + @database_name + ';' +CHAR(10)
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_procedure_execute'')
- BEGIN
- CREATE ROLE [db_procedure_execute] AUTHORIZATION [dbo];
- END ' + CHAR(10);
- --创建数据库角色db_function_execute
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_function_execute'')
- BEGIN
- CREATE ROLE [db_function_execute] AUTHORIZATION [dbo];
- END' + CHAR(10);
- --创建数据库角色db_view_table_definition
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_table_definition'')
- BEGIN
- CREATE ROLE [db_view_table_definition] AUTHORIZATION [dbo];
- END ' + CHAR(10);
- --创建数据库角色db_view_view_definition
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_view_definition'')
- BEGIN
- CREATE ROLE [db_view_view_definition] AUTHORIZATION [dbo];
- END ' + CHAR(10);
- --创建数据库角色db_view_procedure_definition
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_procedure_definition'')
- BEGIN
- CREATE ROLE [db_view_procedure_definition] AUTHORIZATION [dbo];
- END ' + CHAR(10);
- --创建数据库角色db_view_function_definition
- SELECT @cmdText += 'IF NOT EXISTS (SELECT 1 FROM sys.database_principals WHERE name =''db_view_function_definition'')
- BEGIN
- CREATE ROLE [db_view_function_definition] AUTHORIZATION [dbo];
- END ' + CHAR(10);
- --PRINT @cmdText;
- -- EXECUTE SP_EXECUTESQL @cmdText;
- EXECUTE (@cmdText);
- --给角色db_procedure_execute授权
- SET @cmdText ='USE ' + QUOTENAME(@database_name) + ';'
- SET @cmdText +='INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT EXECUTE ON '' + SCHEMA_NAME(schema_id) + ''.''
- + QUOTENAME(name) + '' TO db_procedure_execute;''
- FROM sys.procedures s
- WHERE NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_procedure_execute''))';
- EXECUTE SP_EXECUTESQL @cmdText;
- --给角色db_function_execute(标量函数授权)
- SET @cmdText ='USE ' + QUOTENAME(@database_name) + ';'
- SET @cmdText += 'INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT EXEC ON '' + SCHEMA_NAME(schema_id) + ''.'' + QUOTENAME(name) + '' TO db_function_execute; ''
- FROM sys.all_objects s
- WHERE SCHEMA_NAME(schema_id) NOT IN (''sys'', ''INFORMATION_SCHEMA'')
- AND NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id =USER_ID(''db_function_execute'') )
- AND ( s.[type] = ''FN''
- OR s.[type] = ''AF''
- OR s.[type] = ''FS''
- --OR s.[type] = ''FT''
- ) ;'
- EXECUTE SP_EXECUTESQL @cmdText;
- --给角色db_function_execute(表值函数授权)
- SET @cmdText ='USE ' + @database_name + ';'
- SET @cmdText += 'INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT SELECT ON '' + SCHEMA_NAME(schema_id) + ''.'' + QUOTENAME(name) + '' TO db_function_execute;''
- FROM sys.all_objects s
- WHERE SCHEMA_NAME(schema_id) NOT IN (''sys'', ''INFORMATION_SCHEMA'')
- AND NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_function_execute''))
- AND ( s.[type] = ''TF''
- OR s.[type] = ''IF''
- ) ; '
- EXECUTE SP_EXECUTESQL @cmdText;
- --查看存储过程定义授权
- SET @cmdText ='USE ' + @database_name + ';'
- SET @cmdText +=' INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''
- + QUOTENAME(name) + '' TO db_view_procedure_definition;''
- FROM sys.procedures s
- WHERE NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_view_procedure_definition''))'
- EXECUTE(@cmdText);
- --查看函数定义的授权
- SET @cmdText ='USE ' + @database_name + ';'
- SELECT @cmdText += 'INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''
- + QUOTENAME(name) + '' TO db_view_function_definition;''
- FROM sys.objects s
- WHERE type_desc IN (''SQL_SCALAR_FUNCTION'', ''SQL_TABLE_VALUED_FUNCTION'',
- ''AGGREGATE_FUNCTION'' )
- AND NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_view_function_definition''))';
- EXECUTE SP_EXECUTESQL @cmdText;
- --查看表定义的授权
- SET @cmdText ='USE ' + @database_name + ';'
- SET @cmdText +='INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''
- + QUOTENAME(name) + '' TO db_view_table_definition ;''
- FROM sys.tables s
- WHERE NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_view_table_definition''))';
- EXECUTE SP_EXECUTESQL @cmdText;
- --查看视图定义的授权
- SET @cmdText ='USE ' + @database_name + ';'
- SET @cmdText +='INSERT INTO #sql_text(sql_cmd)
- SELECT ''GRANT VIEW DEFINITION ON '' + SCHEMA_NAME(schema_id) + ''.''
- + QUOTENAME(name) + '' TO db_view_view_definition; ''
- FROM sys.views s
- WHERE NOT EXISTS ( SELECT 1
- FROM sys.database_permissions p
- WHERE p.major_id = s.object_id
- AND p.grantee_principal_id = USER_ID(''db_view_view_definition''))';
- EXECUTE SP_EXECUTESQL @cmdText;
- WHILE 1= 1
- BEGIN
- SELECT TOP 1 @RowIndex=sql_id, @cmdText = 'USE ' + @database_name + '; '+ sql_cmd FROM #sql_text ORDER BY sql_id;
- IF @@ROWCOUNT =0
- BREAK;
- PRINT(@cmdText);
- EXECUTE(@cmdText);
- DELETE FROM #sql_text WHERE sql_id =@RowIndex
- END
- DELETE FROM #databases WHERE database_name=@database_name;
- END
- DROP TABLE #databases;
- DROP TABLE #sql_text;
- END
SQL Server中通用数据库角色权限处理的更多相关文章
- SQL Server中通用数据库角色权限的处理详解
SQL Server中通用数据库角色权限的处理详解 前言 安全性是所有数据库管理系统的一个重要特征.理解安全性问题是理解数据库管理系统安全性机制的前提. 最近和同事在做数据库权限清理的事情,主要是删除 ...
- SQL Server中查询数据库及表的信息语句
/* -- 本文件主要是汇总了 Microsoft SQL Server 中有关数据库与表的相关信息查询语句. -- 下面的查询语句中一般给出两种查询方法, -- A方法访问系统表,适应于SQL 20 ...
- SQL Server 中为何拥有db_owner权限的账号删除不掉数据库
今天在公司的SQL Server服务器上,使用了一个只有public和dbcreator角色的账号"user1"在SMSS中去删除一个数据库,但是死活报错说没有权限,报错如下: D ...
- 解决SQL Server中无管理员账户权限问题
遇到忘记SQL Server管理员账户密码或管理员账户被意外删除的情况,如何在SQL Server中添加一个新的管理员账户?按一下步骤操作可添加一个windows账户到SQL Server中,并分配数 ...
- SQL Server:查看数据库用户权限(SQL 2005)
1. 查看 SQL 2005 用户所属数据库角色 use yourdb go select DbRole = g.name, MemberName = u.name, MemberSID = u.si ...
- 服务器重启可能会导致SQL Server中部分数据库变为single user mode
今天检查公司生产服务器的SQL Server数据库,惊讶的发现有三个生产数据库变为了single user mode.奇怪的是没有任何人和程序执行过SQL语句将这三个数据库设置为single user ...
- 转 在SQL Server中创建用户角色及授权(使用SQL语句)
目录 要想成功访问 SQL Server 数据库中的数据 我们需要两个方面的授权 完整的代码示例 使用存储过程来完成用户创建 实例 要想成功访问 SQL Server 数据库中的数据, 我们需要两个 ...
- 在SQL Server中创建用户角色及授权
参考文献 http://database.51cto.com/art/201009/224075.htm 正文 要想成功访问 SQL Server 数据库中的数据, 我们需要两个方面的授权: 获得准许 ...
- 【转】在SQL Server中创建用户角色及授权(使用SQL语句)
1. 首先在 SQL Server 服务器级别,创建登陆帐户(create login) --创建登陆帐户(create login) create login dba with password=' ...
随机推荐
- 如何在mpvue下收集小程序的formId
什么是formId formId是小程序可以向用户发送模板消息的通行证,简单而言,你只有获取到formId,把它交给后台,后台同学才能向用户发送通知消息,而这个通行证的有效期只有七天.这是微信为了防止 ...
- 浅谈Unity3D 骨骼动画
转载请标明出处http://www.cnblogs.com/zblade/ 最近研究了一下游戏中模型的骨骼动画的原理,做一个学习笔记,便于大家共同学习探讨. ps:最近改bug改的要死要活,博客写的吭 ...
- Google的java工具类Guava
前言 google开发java项目肯定也不想重复造轮子,所以肯定也有工具类,就是它了:Guava 我将举例几个实际的例子,发挥这个工具类好用的功能.更多的方法和功能,还有内部的实现可以直接参考http ...
- Java实现敏感词过滤 - DFA算法
Java实现DFA算法进行敏感词过滤 封装工具类如下: 使用前需对敏感词库进行初始化: SensitiveWordUtil.init(sensitiveWordSet); package cn.swf ...
- Hibernate学习(六)———— cascade(级联)和inverse关系详解
序言 写这篇文章之前,自己也查了很多的资料来搞清楚这两者的关系和各自所做的事情,但是百度一搜,大多数博文感觉说的云里雾里,可能博主自己清楚是怎么一回事,但是给一个不懂的人或者一知半解的人看的话,别人也 ...
- Android studio 下 JNI 开发实例
在AS中进行 NDK 开发之前,我们先来简单的介绍几个大家都容易搞懵的概念: 到底什么是JNI,什么是NDK? 何为“交叉编译”? 先看什么是 JNI?JNI 的全称就是 Java Native In ...
- Java虚拟机——类的结构与加载
1.为什么Java可以跨平台 因为有java虚拟机,跨平台是因为字节码即class文件具有平台无关性,java代码会经过java虚拟机转换为字节码 2.class文件的结构 class文件主要是以8位 ...
- 使用xhprof会在nginx下报502 Bad Gateway错误
使用xhprof会在nginx下报502 Bad Gateway错误 xhprof_enable()xhprof_enable(XHPROF_FLAGS_CPU + XHPROF_FLAGS_MEMO ...
- Java 泛型中的PECS原则
在泛型编程时,使用部分限定的形参时,<? super T>和<? extends T>的使用场景容易混淆,PECS原则可以帮助我们很好记住它们: 生产者(Producer)使用 ...
- java过滤器(简化认证)
最近在看过滤器,刚刚实现了过滤器的简化认证功能: 使用过滤器简化认证: 在Web应用程序中,过滤器的一个关键用例是保护应用程序不被未授权的用户访问.为跨国部件公司开发的客户支持应用程序使用了一种非常原 ...