用普通方式创建的数据库用户,在主数据库中和镜像数据库中是有一些差异的,而这个差异最终会造成一个“奇怪”的结果,我们在主数据库和镜像数据库中对某数据库影射的“相同用户”,在发生故障转移后数据库验证会发生异常,称该用户无法登录我们的数据库,WHY? 原来是两个数据库中的同名用户在系统表syslogins中的sid不同造成的。解决方法就是在两个数据库上建立同名同sid的用户,具体方法如下:
假设有镜像的服务器是MIR-A和MI-B,要访问镜像数据库的登录账号是tom,使用下面这个方法就可以在MIR-A上创建登录名tom,然后在镜像数据库中创建数据库用户tom并映射到登录名tom
执行下列语句取回tom的sid
select [name], sid from syslogins where [name] = 'tom'得到tom的sid为0xD6AABCC8F83E3243A6C3C97F28A4CB55
然后在MIR-B上用下面的语句创建登录名tom
sp_addlogin @loginame = 'tom', @passwd = 'password', @sid = 0xD6AABCC8F83E3243A6C3C97F28A4CB55Ok,这样就没有问题了。
本文介绍如何确保主数据库与镜像数据库中同名用户的SID一致,以避免故障转移后的登录异常。通过创建具有相同SID的登录名,可以有效解决此问题。

7420

被折叠的 条评论
为什么被折叠?



