帮助中心 >  技术知识库 >  数据库 >  相关技术支持 >  ​“用户、组或角色'XXX'在当前数据库中已存在”问题

​“用户、组或角色'XXX'在当前数据库中已存在”问题

2018-11-29 08:08:21 9384

“用户、组或角色'XXX'在当前数据库中已存在”问题


一般在还原数据库后,给这个数据库添加一个登录名时出现。


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


http://www.landui.com/cjh200102/article/details/8669166 这篇文章做了详细的介绍。


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


添加数据库映射相当于给该数据库添加一个同名用户。但是已经存在了abc这个用户了,所以此时会报错。


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


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


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


Use [数据库名]

go

sp_change_users_login 'update_one', 'abc', 'abc'


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: