设为首页收藏本站

EPS数据狗论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 1456|回复: 0

SQLServer之删除用户定义的数据库角色

[复制链接]

18

主题

187

金钱

294

积分

入门用户

发表于 2019-8-26 16:16:40 | 显示全部楼层 |阅读模式

删除用户定义的数据库角色注意事项

无法从数据库删除拥有安全对象的角色。 若要删除拥有安全对象的数据库角色,必须首先转移这些安全对象的所有权,或从数据库删除它们。

无法从数据库删除拥有成员的角色。 若要删除拥有成员的角色,必须首先删除角色的成员。

若要删除数据库角色中的成员,请使用 ALTER ROLE (Transact-SQL)。

不能使用 DROP ROLE 删除固定数据库角色。

在 sys.database_role_members 目录视图中可以查看有关角色成员身份的信息。

若要删除服务器角色,请使用DROP SERVER ROLE (Transact-SQL)。

要求对数据库具有 ALTER ANY ROLE 权限、对角色具有 CONTROL 权限或具有 db_securityadmin 中的成员身份。


使用SSMS数据库管理工具删除用户定义的数据库角色
1、连接服务器-》在对象资源管理器窗口,展开数据库-》选择数据库并展开-》展开安全性-》展开角色-》展开数据库角色-》选择要删除的数据库角色-》右键点击-》选择删除。
1.png
2、在删除对象弹出框-》点击确定。
2.png
3、不需要刷新即可在对象资源管理器窗口看到删除结果。
3.png


使用T-SQL脚本删除用户定义的数据库角色
语法
  1. --声明数据库引用
  2. use database_name;
  3. go

  4. --创建用新的数据库角色之前判断角色是否已存在,如果已存在则删除。
  5. if exists(select * from sys.database_principals where name=role_name)
  6. drop role role_name;
  7. go
复制代码


语法注释
--语法注释
--database_name
--引用数据库名称
--role_name
--指定要从数据库删除的角色。

示例
  1. --声明数据库引用
  2. use [testss];
  3. go

  4. --创建用新的数据库角色之前判断角色是否已存在,如果已存在则删除。
  5. if exists(select * from sys.database_principals where name='testrole')
  6. drop role testrole;
  7. go
复制代码


示例结果:使用T-SQL脚本删除角色需要刷新数据库角色文件夹才能查看删除结果。
4.png
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

站长推荐上一条 /1 下一条

客服中心
关闭
在线时间:
周一~周五
8:30-17:30
QQ群:
653541906
联系电话:
010-85786021-8017
在线咨询
客服中心

意见反馈|网站地图|手机版|小黑屋|EPS数据狗论坛 ( 京ICP备09019565号-3 )   

Powered by BFIT! X3.4

© 2008-2028 BFIT Inc.

快速回复 返回顶部 返回列表