程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> SqlServer數據庫 >> 關於SqlServer >> 更改SQL Server更改當前數據庫的所有者:sp_changedbowner

更改SQL Server更改當前數據庫的所有者:sp_changedbowner

編輯:關於SqlServer

sp_change_users_login

更改當前數據庫中 SQL Server 用戶與 Microsoft® SQL Server™ 登錄之間的關系。

語法

sp_change_users_login [ @Action = ] 'action'
    [ , [ @UserNamePattern = ] 'user' ]
    [ , [ @loginName = ] 'login' ]

參數

[ @Action = ] 'action'

描述此過程要執行的操作。action 的數據類型為 varchar(10),可以是下面的某個值。

值 描述 Auto_Fix 將當前數據庫的 sysusers 表中的用戶條目鏈接到 syslogins 中同名的登錄上。建議檢查 Auto_Fix 語句的結果,確認建立的鏈接是預期的結果。在對安全性較為敏感的情況下,避免使用 Auto_FixAuto_Fix 對鏈接作出最好的估計,授予用戶的訪問權限可能比預期的要多。

user 必須是當前數據庫中的有效用戶,login 必須為 NULL、長度為零的字符串 ('') 或不指定。

Report 列出當前數據庫中未鏈接到任何登錄的用戶及其對應的安全標識號 (SID)。

userlogin 必須為 NULL、長度為零的字符串 ('') 或不指定。

Update_One 將當前數據庫中指定的 user 鏈接到 loginlogin 必須已經存在。必須指定 userlogin

[@UserNamePattern =] 'user'

是當前數據庫中的 SQL Server 用戶的名稱。user 的數據類型為 sysname,默認值為 NULL。sp_change_users_login 只能用於 SQL Server 登錄和用戶的安全帳戶;而不能用於 Microsoft Windows NT® 用戶。

[@LoginName =] 'login'

SQL Server 登錄的名稱。login 的數據類型為 sysname,默認值為 NULL。

返回代碼值

0(成功)或 1(失敗)

結果集
列名 數據類型 描述 UserName sysname 登錄名。 UserSID varbinary(85) 登錄安全標識符。
注釋

使用此過程將當前數據庫中用戶的安全帳戶鏈接到不同的登錄。如果用戶登錄已更改,則使用 sp_change_users_login 將用戶鏈接到新的登錄,而不會丟失用戶的權限。

login 不能為 sa,而 user 不能為 dboguestINFORMATION_SCHEMA 用戶。

不能在用戶定義的事務中執行 sp_change_users_login

權限

任何 public 角色的成員均可執行帶有 Report 選項的 sp_change_users_login。只有 sysadmin 固定服務器角色的成員才能指定 Auto_Fix 選項。只有 sysadmindb_owner 角色的成員才能指定 Update_One 選項。

示例
A. 顯示登錄映射的當前用戶的報告

下面的示例生成當前數據庫中的用戶及其安全標識符的報告。

EXEC sp_change_users_login 'Report'
B. 更改用戶的登錄

下面的示例更改 pubs 數據庫中的用戶 Mary 與現有登錄之間的鏈接,鏈接到新的登錄 NewMary 上(使用 sp_addlogin 添加)。

--Add the new login.
USE master
go
EXEC sp_addlogin 'NewMary'
go
--Change the user account to link with the 'NewMary' login.
USE pubs
go
EXEC sp_change_users_login 'Update_One', 'Mary', 'NewMary'
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved