sql孤立使用者解決方法

2022-02-08 22:34:18 字數 1504 閱讀 6806

如圖,無登入名,所屬為孤立帳戶

其表現可以為:同名在安全性中存在,但是沒存在對某庫的訪問許可權;訪庫安全性中有使用者名稱,為上圖所示。

孤立帳戶,就是某個資料庫的帳戶只有使用者名稱而沒有登入名,這樣的使用者在使用者庫的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 username  

with [,...n ]::=name=newusername

| default_schema=schemaname

| login=loginname

username

指定在此資料庫中用於識別該使用者的名稱。

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 帳號,這些就是...