经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MS SQL Server » 查看文章
SQLServer之删除用户自定义数据库用户
来源:cnblogs  作者:小子pk了  时间:2019/1/9 9:37:18  对本文有异议

删除用户自定义数据库用户注意事项

不能从数据库中删除拥有安全对象的用户。 必须先删除或转移安全对象的所有权,才能删除拥有这些安全对象的数据库用户。

不能删除 guest 用户,但可在除 master 或 tempdb 之外的任何数据库中执行 REVOKE CONNECT FROM GUEST 来撤消它的 CONNECT 权限,从而禁用 guest 用户。

需要对数据库具有 ALTER ANY USER 权限。

使用SSMS数据库管理工具删除用户自定义数据库用户

1、连接服务器-》展开数据库-》选择要删除用户的数据库-》展开数据库-》展开安全性-》展开用户-》选择要删除的用户右键点击-》选择删除。

2、在删除对象弹出框-》点击确定。

3、不需要刷新即可查看删除结果。

使用T-SQL脚本删除用户自定义用户

语法

  1. --声明数据库引用
  2. use database_name;
  3. go
  4. --判断是否存在用户自定义用户,如果存在则删除。
  5. if exists(select * from sys.database_principals where name=user_name)
  6. --把架构所有者修改回来架构自身
  7. alter authorization on schema::[Architecture_name] to Architecture_name;
  8. --删除角色拥有的成员
  9. alter role [[Architecture_name] drop member user_name;
  10. --删除扩展属性
  11. exec sys.sp_dropextendedproperty @name=N'tests_description', @level0type=N'user',@level0name=N'user_name'
  12. --删除用户架构
  13. drop user user_name;
  14. go

语法注释

--database_name
--数据库名称
--user_name
--用户名称
--Architecture_name
--架构名称
--tests_description
--扩展属性名称

示例

  1. --声明数据库引用
  2. use [testss];
  3. go
  4.  
  5. --判断是否存在用户自定义用户,如果存在则删除。
  6. if exists(select * from sys.database_principals where name='test1')
  7. --把架构所有者修改回来架构自身
  8. alter authorization on schema::[db_accessadmin] to db_accessadmin;
  9. --删除角色拥有的成员
  10. alter role [db_accessadmin] drop member test1;
  11. --删除扩展属性
  12. --exec sys.sp_dropextendedproperty @name=N'tests_description', @level0type=N'user',@level0name=N'test1'
  13. --删除用户架构
  14. drop user test1;
  15. go

示例结果:使用T-SQL脚本删除用户需要刷新用户文件夹才能查看删除结果。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号