[SQL Server]關於15517號錯誤的一點想法

來源:互聯網
上載者:User

將一個資料庫分離,然後在另一台電腦上附加,可能會出現這樣的情況:在使用有限許可權的使用者執行一些預存程序的時候會出現15517號錯誤:無法作為資料庫主體執行,因為主體 "dbo" 不存在、無法類比這種類型的主體,或您沒有所需的許可權。

引發這種錯誤的預存程序都有一個WITH EXECUTE AS選項,指定了OWNER或者別的使用者(登入名稱)。

例如,我在自己的電腦上用Windows身分識別驗證登入,建立了一個資料庫,並在資料庫中建立了一個帶有WITH EXECUTE AS OWNER選項的預存程序。然後分離這個資料庫,在別人的電腦上附加,此時如果運行這個預存程序,就會引發上面提到的錯誤。

造成這個錯誤的原因是WITH EXECUTE AS選項指定的使用者(登入名稱)在當前的伺服器中不存在。當我用Windows身分識別驗證登入伺服器並建立一個資料庫時,這個資料庫的所有者就是我所使用的Windows賬戶,在本機執行預存程序時,SQL Server會找到這個使用者並以它的身份來執行預存程序。然而,當把資料庫附加到另一台電腦上時,那台電腦的系統上並沒有我電腦上這個賬戶,在執行預存程序時找不到該使用者,所以引發了錯誤。

要解決這個錯誤,可以修改資料庫的所有者,例如執行以下命令:

 

ALTER AUTHORIZATION ON DATABASE::[<Database's Name] TO [sa]

就把指定資料庫的所有者改為sa。sa在所有的SQL Server伺服器中都存在,所以不會出現上述錯誤。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.