• 设为首页
  • 收藏本站
  • 积分充值
  • VIP赞助
  • 手机版
  • 微博
  • 微信
    微信公众号 添加方式:
    1:搜索微信号(888888
    2:扫描左侧二维码
  • 快捷导航
    福建二哥 门户 查看主题

    SQLServer错误:15023(创建对于用户失败)_数据库恢复到其他服务器

    发布者: 涵韵 | 发布时间: 2025-6-17 14:16| 查看数: 90| 评论数: 0|帖子模式

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

    下面讲一下解决的方法。
    1. 分析:   
    2. SQL Server中“登录”与“用户”的区别,“登录”用于用户身份验证,而数据库“用户”帐户用于数据库访问和权限验证。登录通过安全识别符 (SID) 与用户关联。
    3. 将数据库恢复到其他服务器时,数据库中包含一组用户和权限,但可能没有相应的登录或者登录所关联的用户可能不是相同的用户。这种情况被称为存在“孤立用户”。
    4. 此时是不能通过新建登录或者是对同名登录授予对应数据库的“用户”权限来解决登录问题,因为SQL Server会报出“错误15023:当前数据库中已存在用户或角色”
    复制代码
    简单理解:
    数据库备份文件中已经包含了用户test,现在还原了数据库,然后发现现有数据库中没有test这个用户,想要新建一个test用户,作为该数据库的owner,便会出现这个问题。
    可以理解为登录名和用户是两个不同的概念,虽然名称相同。在新建登录名的时候,如果不添加该数据库映射则不会报错。添加数据库映射相当于给该数据库添加一个同名用户。
    但是已经存在了test这个用户了,所以此时会报错。
    解决方法:
    可以通过以下方法解决该问题。
    1.新建一个test登录名,但是不要添加数据库映射。
    2.使用脚本,将孤立用户test关联到登录名test上:
    1. Use Northwind
    2. Go
    3. sp_change_users_login 'update_one', 'test', 'test'
    复制代码
    其中Northwind为存在孤立用户的数据库,update_one是存储过程的参数,表示只处理一个用户,前一个test是“用户”,后一个test是“登录”,
    以上这个SQL表示将服务器登录“test”与 Northwind 数据库用户“test”重新连接起来。这样就可以正常使用数据库了。


    到此这篇关于SQLServer错误:15023(创建对于用户失败)_数据库恢复到其他服务器的文章就介绍到这了,更多相关SQLServer用户“xx”的创建失败(Microsoft.SqlServer.Smo)内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    来源:https://www.jb51.net/database/3372339x7.htm
    免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

    本帖子中包含更多资源

    您需要 登录 才可以下载或查看,没有账号?立即注册

    ×

    最新评论

    浏览过的版块

    QQ Archiver 手机版 小黑屋 福建二哥 ( 闽ICP备2022004717号|闽公网安备35052402000345号 )

    Powered by Discuz! X3.5 © 2001-2023

    快速回复 返回顶部 返回列表