SQLServer 报错:用户、组或角色‘XXX‘ 在当前数据库中已存在. 错误:15023.

背景: 最近在迁移SQLServer数据库2008时,新建用户后,做用户映射时。 SQLServer 报错:用户、组或角色'XXX' 在当前数据库中已存在. 错误:15023.

下面讲一下解决的方法。

QQ图片20160908093002

分析:    
将数据库恢复到其他服务器时,数据库中包含一组用户和权限,但可能没有相应的登录或者登录所关联的用户可能不是相同的用户。    
这种情况被称为存在“孤立用户”。此时是不能通过新建登录或者是对同名登录授予对应数据库的“用户”权限来解决登录问题,    
因为SQLServer会报出“错误15023:当前数据库中已存在用户或角色”,

简单理解

数据库备份文件中已经包含了用户ulequeryuser,现在还原了数据库,然后发现现有数据库中没有ulequeryuser这个用户,想要新建一个ulequeryuser用户,作为该数据库的owner,便会出现这个问题。

可以理解为登录名和用户是两个不同的概念,虽然名称相同。在新建登录名的时候,如果不添加该数据库映射则不会报错。添加数据库映射相当于给该数据库添加一个同名用户。

但是已经存在了ulequeryuser这个用户了,所以此时会报错。

解决方法

可以通过以下方法观察某个数据库是否存在这种“孤立用户”

1、USE [db]

2、exec sp_change_users_login 'REPORT'

即可列出此db下所有的孤立用户。

可以通过以下方法解决该问题。

1.新建一个ulequeryuser登录名,但是不要添加数据库映射。

2.使用脚本,将孤立用户ulequeryuser关联到登录名ulequeryuser上:

Use [db]

go

sp_change_users_login 'update_one', 'ulequeryuser', 'ulequeryuser'

或者

use [db]

exec sp_change_users_login 'AUTO_FIX','ulequeryuser'

其他相关问题

如果此ulequeryuser还关联了master数据库下的公用函数,那么

1、安全性↠↠↠↣↣↣登录名↠↠↠↣↣↣ulequeryuser↠↠↠↣↣↣右键↠↠↠↣↣↣属性↠↠↠↣↣↣用户映射↠↠↠↣↣↣master

2、master↠↠↠↣↣↣右键↠↠↠↣↣↣可编程↠↠↠↣↣↣函数↠↠↠↣↣↣标题函数名称↠↠↠↣↣↣右键↠↠↠↣↣↣权限↠↠↠↣↣↣添加ulequeryuser↠↠↠↣↣↣可执行

  • 4
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值