SQL Server 设置新用户只能查看并访问特定数据库
解决方案
1、先给不同的服务商创建不同的登录名(如下以一个服务商为例)
2.将登录名加入到public服务器角色中
3.将public服务器角色的属性——>安全对象中取消查看所有数据库的权限
或者执行如下SQL:
REVOKE VIEW ANY DATABASE TO [public]
4.将待授权的数据库的dbowner指派给该用户
执行sql
USE ZYLTEST go EXEC dbo.sp_changedbowner N'zyl'
效果图
注意:此处的设置不能手动取消,会有错误提示:
解决办法,执行sql修改该数据库的所有者
USE ZYLTEST go EXEC dbo.sp_changedbowner N'sa'
效果图
5、此时用登录名'zyl'登录sql server,便只能看到指定的数据库了
#TIPS
上述方案实现的是-“设置登录用户只能看到和操作特定数据库”,如果你只想实现-“设置登录用户只能操作特定数据库,但能看到所有数据库,只是有的数据库不能操作”
需要对上述方案稍作修改,具体步骤:
1、取消上述方案的第三步;
2、将上述方案的第四步修改为如下操作:
3、效果图
可以看到所有的数据库,但是无法查看未授权的数据内容,如图提示
原文链接:https://www.cnblogs.com/willingtolove/p/9122738.html
该努力的时候努力
该休息的时候休息
分类:
数据库_SqlServer
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构