为SQL Server快照snapshot DB建立login访问

为了提供sql server的报表查询功能,通常在备库mirror上建立定时snapshot job以提供web查询。


但是众所周知的是快照DB只读不可写,所以直接在备库建立login mapping及赋权限时会报错:
USE [WEB02]
GO
CREATE USER [test] FOR LOGIN [test]
GO
USE [WEB02]
GO
EXEC sp_addrolemember N'db_datareader', N'test'
GO

Failed to update database "WEB02" because the database is read-only. (Microsoft SQL Server, Error: 3906)


建立方法:
1.先在主库创建login及mapping对应db的user


2.查询主库中新建login的sid
执行:
select name,sid from sys.server_principals 

或 select name,sid from sys.sql_logins


3.然后备库中新建login,并设置sid等于主库login的sid
USE [master]
GO
CREATE LOGIN [test] WITH PASSWORD=N'test', DEFAULT_DATABASE=[master], CHECK_EXPIRATION=OFF, CHECK_POLICY=OFF sid=0xA366990EC2C0EE47B8826E5DAB5851CD
GO


至此完成,

下次刷新建立快照后,login及user相关权限即可和主库同步,也就可以使用login访问快照DB了。


来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/25583515/viewspace-2644981/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/25583515/viewspace-2644981/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值