29
2021
12
17:14:35

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

今天在给数据库账号分配数据库权限的时候,直接抛出抛出错误,错误的详细信息如下:用户、组或角色 '' 在当前数据库中已存在。 (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服务器时提示:“拒绝了对对象 'xxx' (数据库'xxx',架构'dbo')的SELECT权限”这是由于所连接的用户没有使用SELECT语句访问的权限

这时只要打开SQL Server Management Studio管理器对相应的用户进行设置就可以了,登录时需要使用windows身份验证,使用本地账户登录,以保证有权限进行设置。

登录后依次展开左边对象资源管理器的“数据库”》要访问的“数据库名”》“安全性”》“架构”,然后在‘dbo’上点右键,在弹出对话框中点属性,会弹出上面窗口,然后点“权限”》“搜索”,输入public》“检查名称”》“确定”,然后出现下面的窗口,把需要的权限全勾上,然后点确定就可以了。

如果在“数据库”》“安全性”》“用户”里面看不到你的用户名,说明还没有为该用户设置访问这个数据库的权限,这时可以在“安全性”》“登录名”里找到相应的用户名,在相应用户名上点名键,(如果还没有用户,可以在“登录名”或任意一个用户名上点右键,然后点“新建登录名”),默认有一个名为“sa”的用户,可以直接启用。我是直接新建了一个用户。

在常规页里选择使用SQL Server身份验证,把“强制实施密码策略”的勾去掉,如下图所示

然后在服务器角色页里,确认public被色上,默认勾选。

然后在用户映射页里把要访问的数据库勾选上。

然后在安全对象里把需要的权限也勾选上。

最后在状态页里,确认是否允许连接数据库引擎选择“是”,登录名选择“启用”

如果后面这几步没有设置的话会弹出一个错误提示“microsoft sql server 错误:18456”,如果看到这样的提示,只需要按后面的步骤设置好就可以了。

配置完了,重启一下SQL服务器,首先打开SQL配置管理器,然后在SQL SERVER上点右键,选择重启服务就可以了。






推荐本站淘宝优惠价购买喜欢的宝贝:

image.png

本文链接:https://hqyman.cn/post/2045.html 非本站原创文章欢迎转载,原创文章需保留本站地址!

分享到:
打赏





休息一下~~


« 上一篇 下一篇 »

发表评论:

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

请先 登录 再评论,若不是会员请先 注册

您的IP地址是: