用sp_change_users_login消除Sql Server的孤立使用者

iSQlServer發表於2010-01-25

今天同事問一個問題:

問題:1. sql server2005 修改系統表不能修改
        2. 錯誤資訊:sql server 2005 使用者、組或角色 在當前資料庫中已存在,想手工把登入名與資料庫中的使用者名稱進行關聯, 系統不讓; 想刪除資料庫中的使用者再重建, 竟然也不讓刪……

 

孤立帳戶,就是某個資料庫的帳戶只有使用者名稱而沒有登入名,這樣的使用者在使用者庫的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','使用者名稱','登入名'
將使用者名稱對映為指定的登入名。

來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-625919/,如需轉載,請註明出處,否則將追究法律責任。

相關文章