一般在還原數據庫后,給這個數據庫添加一個登錄名時出現。
例如數據庫備份文件中已經包含了用戶abc,現在還原了數據庫,然后發現現有數據庫中沒有abc這個用戶,想要新建一個abc用戶,作為該數據庫的owner,便會出現這個問題。
http://blog.csdn.net/cjh200102/article/details/8669166 這篇文章做了詳細的介紹。
可以理解為登錄名和用戶是兩個不同的概念,雖然名稱相同。在新建登錄名的時候,如果不添加該數據庫映射則不會報錯。
添加數據庫映射相當於給該數據庫添加一個同名用戶。但是已經存在了abc這個用戶了,所以此時會報錯。
可以通過以下方法解決該問題。
1.新建一個abc登錄名,但是不要添加數據庫映射。
2.使用腳本,將孤立用戶abc關聯到登錄名abc上:
Use [數據庫名]
go
sp_change_users_login 'update_one', 'abc', 'abc'
