sqlserver 限制用户只能访问指定的视图
项目中有一个需求,要求给其它单位提供数据,我们用到了视图,并要求不能让他们看到数据库中的其它数据,我们为其创建了单独的账号,并只能看到指定视图
一、创建视图
CREATE VIEW [dbo].[v_Insurance_abroadPerson] AS SELECT TOP (100) PERCENT e.ReceivedletterNumber AS groupId, e.Principle AS ContactName, e.Email
FROM dbo.Ea AS e INNER JOIN dbo.chgrymd AS p ON p.xmbh = e.ReceivedletterNumber
INNER JOIN dbo.unitinfo AS u ON u.dm = e.unit_code
INNER JOIN dbo.ryk AS r ON r.xmbm = p.xmbm INNER JOIN dbo.Purpose AS pp ON e.mission_type = pp.Id
ORDER BY p.groupid
二、创建用户,并为用户指定访问该视图的权限
1、创建角色 seeviewForInsurance
exec sp_addrole 'seeviewForInsurance'
2、结角色赋查看视图的权限,视图名为:v_Insurance_abroadPerson 角色名为创建的角色 seeviewForInsurance
grant select on v_Insurance_abroadPerson to seeviewForInsurance
3、创建用户,并为用户指定默认的数据库,用户名:abroadInsurance 密码:12345abc123! 默认的数据库:cnpc
exec sp_addlogin 'abroadInsurance','12345abc123!','cnpc'
4、将用户和角色进行绑定 ‘用户’,‘密码’,‘角色’
exec sp_adduser 'abroadInsurance','12345abc123!','seeviewForInsurance'
注:这个密码如果长度和强度不够的话是执行不了的。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
2017-07-27 C# XmlDocument操作XML
2017-07-27 C# xml增删查改