zoukankan      html  css  js  c++  java
  • SQLServer 报错:用户、组或角色'XXX' 在当前数据库中已存在. 错误:15023解决方法

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

    pizibaidu关注0人评论3332人阅读2016-09-08 11:31:57

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

    下面讲一下解决的方法。

    QQ图片20160908093002

     

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

     

    简单理解

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

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

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

     

    解决方法

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

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

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

    Use [数据库名]

    go

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

  • 相关阅读:
    js动态添加CSS
    LINUX命令行回滚SVN版本
    LINUX文件名批量修改
    LINUX下文件编码转换 iconv
    ubuntu下eclipse的svn插件使用javahl
    HTML5学习笔记 本地数据库
    正则表达式
    我的第一篇博客
    【分布式锁的演化】分布式锁居然还能用MySQL?
    【分布式锁的演化】终章!手撸ZK分布式锁!
  • 原文地址:https://www.cnblogs.com/grj001/p/12225614.html
Copyright © 2011-2022 走看看