解决SQL Server数据库的"User, group, or role

系统 1681 0

问题场景

在SQL Server数据库迁移时,在另外一台服务器上恢复数据库备份文件之后,需要重新创建之前数据库上的用户帐户。在创建登录用户时,需要在User Mapping中给该用户针对具体的数据库进行授权,由于恢复出来的数据库中存在同名的用户帐户,创建时会出现"User, group, or role already exists in the current database"的错误提示。详细错误信息如下:

TITLE: Microsoft SQL Server Management Studio
------------------------------
Create failed for User 'testuser'.  (Microsoft.SqlServer.Smo)
------------------------------
ADDITIONAL INFORMATION:
An exception occurred while executing a Transact-SQL statement or batch. (Microsoft.SqlServer.ConnectionInfo)
------------------------------
User, group, or role 'testuser' already exists in the current database. (Microsoft SQL Server, Error: 15023)

之前的解决方法

在创建用户帐户(或者授权)之前,先在对应的数据库中删除该同名的用户帐户。

最新的解决方法

先创建用户帐户,不进行授权,然后通过下面的SQL语句将该用户帐户关联至对应的数据库用户。优点是避免了重新授权的操作。

      
        USE
      
      
         {目标数据库}


      
      
        EXEC
      
       sp_change_users_login 
      
        '
      
      
        Update_One
      
      
        '
      
      , 
      
        '
      
      
        {目标数据库已存在的用户名}
      
      
        '
      
      , 
      
        '
      
      
        {创建的登录用户名}
      
      
        '
      
    

方法来源

SQL Server Forums - How to assign a login to an existing user?

解决SQL Server数据库的"User, group, or role already exists in the current database"问题


更多文章、技术交流、商务合作、联系博主

微信扫码或搜索:z360901061

微信扫一扫加我为好友

QQ号联系: 360901061

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描下面二维码支持博主2元、5元、10元、20元等您想捐的金额吧,狠狠点击下面给点支持吧,站长非常感激您!手机微信长按不能支付解决办法:请将微信支付二维码保存到相册,切换到微信,然后点击微信右上角扫一扫功能,选择支付二维码完成支付。

【本文对您有帮助就好】

您的支持是博主写作最大的动力,如果您喜欢我的文章,感觉我的文章对您有帮助,请用微信扫描上面二维码支持博主2元、5元、10元、自定义金额等您想捐的金额吧,站长会非常 感谢您的哦!!!

发表我的评论
最新评论 总共0条评论