MEIMIAO2020

MeiMiao space记录是一件开心的事情,沉浸只是因为纯粹的灵感。

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

发布于 2024-06-29

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


下面讲一下解决的方法。

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

简单理解:

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

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

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

解决方法:
可以通过以下方法解决该问题。
1.新建一个test登录名,但是不要添加数据库映射。
2.使用脚本,将孤立用户test关联到登录名test上:

解决办法(下面以test数据库为例,登录名为ReadData):

use test
go
sp_change_users_login 'update_one','ReadData','ReadData'

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

例如:

USE 相应数据库
go
sp_change_users_login 'update_one','GBOY','GBOY'

暂无留言

留言