Sql Server设置用户只能查看并访问特定数据库

现需要限定特定的用户只能查看并访问特定的数据库,防止多个用户对数据库操作时一些误操作。 
参考i6first的如何让用户只能访问特定的数据库(MSSQL)博文

1.新建登录用户 
以管理员身份登陆数据库(权限最高的身份如sa),点击安全性->登录名,右键新建登录名,输入登录名和密码,取消强制实施密码策略。 
新建登录名

2.将服务器角色设置为public 
服务器角色设置

3.将public服务器角色的属性->取消查看所有数据库的权限 
点击安全性->服务器角色->public,右键属性。点击服务器后如下图取消查看任意数据库的权限

服务器角色属性设置

或者执行如下SQL: 
REVOKE VIEW ANY DATABASE TO [public]

4.将待授权的数据库的db_owner指派给刚注册的新用户 
在数据库中新建查询,输入下列sql语句。完成对用户权限的设定,做到了新建用户只能查看和操作特定数据库(除系统数据库外)

Use [WH_R]//WH_R为数据库名称
go
EXEC dbo.sp_changedbowner N'user'//user为刚新建的用户
  • 1
  • 2
  • 3

数据库权限设置结果

posted @ 2019-10-15 10:58  cnplayboy  阅读(5436)  评论(1编辑  收藏  举报