sqlserver中回收用户权限后还能访问的问题

问题描述

在使用sqlserver创建用户并赋予权限后,然后撤销用户权限后,用户还能继续访问的问题,话不多说,上图!!!

–为用户chen分配所有test中 Course表的所有权限,并允许chen将所拥有的权限授予其他用户

use test
grant all on Course to chen
with grant option

经过查看雀氏赋予成功了
在这里插入图片描述

然后对该权限进行撤销所有权限

revoke all on Course from chen Cascade

在这里插入图片描述

并没有撤销,那我们就登录chen用户看一下是否真的像我们想的那样吧

在这里插入图片描述

果然还是没有成功撤销



解决方案:

然后遇到这个问题我们应该如何解决呢?
在这里插入图片描述
经过观察我们发现chen居然有这么多架构(架构:架构看成一个存放数据库中对象的一个容器)
然后我们要做的就是将用户chen从这些架构中移除即可

在这里插入图片描述
在这里插入图片描述

右键属性,将架构所有者改为架构的名字就OKl

在这里插入图片描述
结果我修改后发现还是能够访问,人麻了。。。
在这里插入图片描述
结果我将创建的用户比对了好久,发现我居然将数据库拥有者的权限赋予了chen...
在这里插入图片描述

在这里插入图片描述

取消勾选即可!!!
或者使用命令(第一个参数为角色名,第二个参数为用户名)

sp_droprolemember ‘db_owner’,‘chen’

在这里插入图片描述

总结

通过这个小故事也告诉大家,以后在是有revoke撤销用户部分权限的时候要注意去观察你之前给用户赋予了什么角色(个人理解是权限的封装),比如这钱赋予用户db_owner的角色,那么你是用revoke selcet......肯定是没用的,需要撤销赋予用户的角色,在sqlserver中可以使用

sp_droprolemember 'db_owner','chen'  
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值