SQL Server 创建用户时报错:15023 用户,组或角色'XXX'在当前数据库中已存在


今天遇到了这个问题,将找到的解决方案做了个整理,如下:

一、原因分析

      sql server数据库从一台机转移到另一台机时,登录名没转移,或者只删除了登录名。这种情况将会产生“孤立用户”(孤立用户定义:将数据库恢复到其它服务器时,数据库中包含一组用户和权限,但可能没有相应的登录或者登录所关联的用户),此时是不能通过新建登录或者对同名登录授予对应数据库用户权限来解决下面问题。

报错信息:用户、组或角色 'XX' 在当前数据库中已存在。(Microsoft SQL Server,错误:15023)

二、解决方案:

Use mlhgo

sp_change_users_login 'update_one','test','test'

说明:mlh为数据库名,update_one为存储过程的参数(表示只处理一个用户),前一个test为“用户”,后一个test为“登录”,(sql server中的“登录”与“用户”的区别,“登录”用于用户身份验证,而"用户"账户用于数据库访问和权限验证。登录通过安全识别符(SID) 与用户关联),以上这个sql语句使得用test登录数据库并与mlh数据库的用户“test”重新连接,这样用test登录就可以正常操作数据库了。

三、知识扩展:

所谓孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录

孤立帐户的产生一般是一下两种:
1.将备份的数据库在其它机器上还原;
2.重装系统或SQL SERVER之后只还原了用户库

解决方法是使用sp_change_users_login来修复


sp_change_users_login的用法有三种

用法1:
exec sp_change_users_login 'REPORT'

列出当前数据库的孤立用户

用法2:
exec sp_change_users_login 'AUTO_FIX','用户名'

可以自动将用户名所对应的同名登录添加到syslogins中

用法3:
exec sp_change_users_login 'UPDATE_ONE','用户名','登录名'
将用户名映射为指定的登录名

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值