酷酷娱乐网

站内广告

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

时间:2020-09-24 08:30:02   作者:酷酷娱乐网   来源:www.kukuyl.com  
内容摘要:

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

为了提供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了。


本文章url:https://www.kukuyl.com/new/30000904.html

相关文章

本栏最新更新

本栏推荐

阅读排行

CopyRight 2018 - 2020 http://www.kukuyl.com 酷酷娱乐网 All Rights Reserved .