如圖,無登入名,所屬為孤立帳戶
其表現可以為:同名在安全性中存在,但是沒存在對某庫的訪問許可權;訪庫安全性中有使用者名稱,為上圖所示。孤立帳戶,就是某個資料庫的帳戶只有使用者名稱而沒有登入名,這樣的使用者在使用者庫的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
','使用者名稱
','登入名
'將使用者名稱對映為指定的登入名。
使用alter user
with login修復孤兒登入
/*
alter user usernameusernamewith [,...n ]::=name=newusername
| default_schema=schemaname
| login=loginname
指定在此資料庫中用於識別該使用者的名稱。
login=loginname
通過將使用者的安全識別符號 (sid) 更改為另乙個登入名的 sid,使使用者重新對映到該登入名。
name=newusername
指定此使用者的新名稱。newusername 不能已存在於當前資料庫中。
default_schema=schemaname
指定伺服器在解析此使用者的物件名時將搜尋的第乙個架構。
*/從sql server 2005 sp2開始,t-sql的alter user命令就包含了with login子句,這個子句通過修改資料庫使用者的sid為伺服器登入的安全識別符號修復孤兒登入,它可以同時修復windows和sql server登入的功能。**:
mysql孤立鎖 SQL孤立使用者解決方案
中國最大的web開發資源 及技術社群,prb 聯機叢書中的 孤立使用者疑難解答 主題不完整 文章 id 274188 最後更新日期 2004年5月31日 版本 1.0 本頁內容 症狀狀態 更多資訊 參考症狀 當您將資料庫備份恢復到另一台伺服器時,可能會遇到孤立使用者的問題。sql server 聯機...
SQL注入解決方法
簡單又有效的方法 preparedstatement 採用預編譯語句集,它內建了處理sql注入的能力,只要使用它的set 方法傳值即可。使用好處 1 的可讀性和可維護性.2 preparedstatement盡最大可能提高效能.3 最重要的一點是極大地提高了安全性.原理 sql注入只對sql語句的準...
Sql Server 孤立使用者解決辦法
sql server 孤立使用者 是我們經常遇到的事情,今天詳細的梳理了下,希望能幫到你 當把使用者資料庫從一台 sql server 使用備份和恢復的方式遷移到另一台伺服器。資料庫恢復以後,原先使用者定義的一些其他資料庫使用者,就無法在新伺服器上繼續使用了。尤其對一些sql ser 帳號,這些就是...