地下室的流星雨
看一个人是否聪明看他的答案;看一个人是否有智慧看他的问题。

 


孤立帐户,就是某个数据库的帐户只有用户名而没有登录名,这样的用户在用户库的sysusers系统表中存在,而在master数据库的syslogins中却没有对应的记录。

 

孤立帐户的产生一般是一下两种:


1.将备份的数据库在其它机器上还原;
2.重装系统或SQL SERVER之后只还原了用户库

 

解决方法是使用sp_change_users_login来修复。

 

sp_change_users_login的用法有三种

 

用法1:
exec sp_change_users_login 'REPORT'

列出当前数据库的孤立用户

 

用法2:
exec sp_change_users_login 'AUTO_FIX','用户名'

可以自动将用户名所对应的同名登录添加到syslogins中

 

用法3:
exec sp_change_users_login 'UPDATE_ONE','用户名','登录名'
将用户名映射为指定的登录名。

 

在上次恢复数据库后,由于此数据库在恢复后有一个孤立用户xxx,为了解决登录名同孤立用户的问题,先建立一个登录名为xxx的登录名,然后调用 EXEC sp_change_users_login 'AUTO_FIX','xxx'执行之后就关联解决

 

posted on 2012-08-06 09:27  地下室的流星雨  阅读(295)  评论(0编辑  收藏  举报