Sqlserver用户、组或角色在当前数据库中已存在

发布时间:2020-08-26 17:47:57 作者:宇宙小元帅
来源:网络 阅读:686

今天在给数据库账号分配数据库权限的时候,直接抛出抛出错误,错误的详细信息如下:用户、组或角色 '' 在当前数据库中已存在。 (Microsoft SQL Server,错误: 15023)。查阅相关文档后发现,抛出这种错误,可能是因为数据库中存在孤立用户。

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

为了能够使数据库账号顺利的赋权访问该数据库,可以采用Sqlserver内置的系统存储过程sp_change_users_login来解决此问题。

解决此问题的步骤如下:

1、登录到Sqlserver管理工具,连接服务器成功后,在新建查询窗口输入以下语句即可解决。

Use [数据库名]
go
exec sp_change_users_login 'UPDATE_ONE','用户名','登录名'

此语句将用户名映射为指定的登录名。

2、举个例子将ADataBase数据库中的user1用户与登录名user1相关联,则可使用以下语句。

Use ADataBase
go
exec sp_change_users_login 'UPDATE_ONE','user1','user1'

扩展阅读:Sqlserver修改默认端口号增加安全性。

备注:此原创文章最早发表于自博主个人技术站点。原文链接:Sqlserver用户、组或角色在当前数据库中已存在_IT技术小趣屋。

博主个人技术交流群:960640092,博主微信公众号如下:
Sqlserver用户、组或角色在当前数据库中已存在

推荐阅读:
  1. oracle中用户删除不了,提示“无法删除当前已连接的用户”
  2. 怎么在SQL Server中处理数据库角色权限

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

sqlserver 授权 用户

上一篇:shell下的字符串截取方法

下一篇:HDFS中JAVA API的使用

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》