文章内容

2023/6/8 2:22:56,作 者: 黄兵

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

今天在给数据库账号分配数据库权限的时候,直接抛出抛出错误,错误的详细信息如下:用户、组或角色在当前数据库中已存在。 (Microsoft SQL Server,错误: 15023)。

出现问题的原因:

查阅相关文档后发现,抛出这种错误,可能是因为数据库中存在孤立用户。

将数据库恢复到其他服务器时,数据库中包含一组用户和权限,但可能没有相应的登录或者登录所关联的用户可能不是相同的用户。

这种情况被称为存在“孤立用户”。

此时是不能通过新建登录或者是对同名登录授予对应数据库的“用户”权限来解决登录问题,因为SQLServer 会报出“错误15023:当前数据库中已存在用户或角色“。

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

解决此问题的步骤如下:

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

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'


其它相关推荐:

1、SQL Server Profiler工具

2、Microsoft SQL Server 错误 18456 疑难解答

3、SQL Server如何查看SQL语句的执行时间

4、安装SQL2005 29506错误码的解决方案

5、Entity Framework code first 手动修改数据库的问题

分享到:

发表评论

评论列表