SQLServer之删除用户自定义数据库用户
程序员文章站
2023-10-11 19:20:33
删除用户自定义数据库用户注意事项 不能从数据库中删除拥有安全对象的用户。 必须先删除或转移安全对象的所有权,才能删除拥有这些安全对象的数据库用户。 不能删除 guest 用户,但可在除 master 或 tempdb 之外的任何数据库中执行 REVOKE CONNECT FROM GUEST 来撤消 ......
删除用户自定义数据库用户注意事项
不能从数据库中删除拥有安全对象的用户。 必须先删除或转移安全对象的所有权,才能删除拥有这些安全对象的数据库用户。
不能删除 guest 用户,但可在除 master 或 tempdb 之外的任何数据库中执行 revoke connect from guest 来撤消它的 connect 权限,从而禁用 guest 用户。
需要对数据库具有 alter any user 权限。
使用ssms数据库管理工具删除用户自定义数据库用户
1、连接服务器-》展开数据库-》选择要删除用户的数据库-》展开数据库-》展开安全性-》展开用户-》选择要删除的用户右键点击-》选择删除。
2、在删除对象弹出框-》点击确定。
3、不需要刷新即可查看删除结果。
使用t-sql脚本删除用户自定义用户
语法
--声明数据库引用
use database_name;
go
--判断是否存在用户自定义用户,如果存在则删除。
if exists(select * from sys.database_principals where name=user_name)
--把架构所有者修改回来架构自身
alter authorization on schema::[architecture_name] to architecture_name;
--删除角色拥有的成员
alter role [[architecture_name] drop member user_name;
--删除扩展属性
exec sys.sp_dropextendedproperty @name=n'tests_description', @level0type=n'user',@level0name=n'user_name'
--删除用户架构
drop user user_name;
go
语法注释
--database_name
--数据库名称
--user_name
--用户名称
--architecture_name
--架构名称
--tests_description
--扩展属性名称
示例
--声明数据库引用
use [testss];
go
--判断是否存在用户自定义用户,如果存在则删除。
if exists(select * from sys.database_principals where name='test1')
--把架构所有者修改回来架构自身
alter authorization on schema::[db_accessadmin] to db_accessadmin;
--删除角色拥有的成员
alter role [db_accessadmin] drop member test1;
--删除扩展属性
--exec sys.sp_dropextendedproperty @name=n'tests_description', @level0type=n'user',@level0name=n'test1'
--删除用户架构
drop user test1;
go
示例结果:使用t-sql脚本删除用户需要刷新用户文件夹才能查看删除结果。
上一篇: 陈瑞钿的身份为什么不被国民*承认 不被承认的原因是什么
下一篇: Oracle登录指令
推荐阅读
-
MSSQL中删除用户时数据库主体在该数据库存中拥有架构 无法删除的解决方法
-
SQLServer 数据库变成单个用户后无法访问问题的解决方法
-
MSSQL 删除数据库里某个用户所有表里的数据
-
SQLServer删除登录记录用户名和密码
-
MSSQL中删除用户时数据库主体在该数据库存中拥有架构 无法删除的解决方法
-
SQLServer 数据库变成单个用户后无法访问问题的解决方法
-
Mysql数据库高级用法之视图、事务、索引、自连接、用户管理实例分析
-
oracle数据库解锁表、删除用户和表空间等操作讲解
-
SQLServer之删除用户自定义数据库用户
-
数据库备份、还原、删除、收缩,创建登录用户,数据库用户等操作脚本