更改SQL Server更改當(dāng)前數(shù)據(jù)庫(kù)的所有者:sp_changedbowner
sp_change_users_login
更改當(dāng)前數(shù)據(jù)庫(kù)中 SQL Server 用戶與 Microsoft® SQL Server™ 登錄之間的關(guān)系。
語(yǔ)法
sp_change_users_login [ @Action = ] 'action'
[ , [ @UserNamePattern = ] 'user' ]
[ , [ @login
Name = ] 'login' ]
參數(shù)
[ @Action = ] 'action'
描述此過(guò)程要執(zhí)行的操作。action 的數(shù)據(jù)類型為 varchar(10),可以是下面的某個(gè)值。
值 | 描述 |
---|---|
Auto_Fix | 將當(dāng)前數(shù)據(jù)庫(kù)的 sysusers 表中的用戶條目鏈接到 syslogins 中同名的登錄上。建議檢查 Auto_Fix 語(yǔ)句的結(jié)果,確認(rèn)建立的鏈接是預(yù)期的結(jié)果。在對(duì)安全性較為敏感的情況下,避免使用 Auto_Fix。Auto_Fix 對(duì)鏈接作出最好的估計(jì),授予用戶的訪問(wèn)權(quán)限可能比預(yù)期的要多。
user 必須是當(dāng)前數(shù)據(jù)庫(kù)中的有效用戶,login 必須為 NULL、長(zhǎng)度為零的字符串 ('') 或不指定。 |
Report | 列出當(dāng)前數(shù)據(jù)庫(kù)中未鏈接到任何登錄的用戶及其對(duì)應(yīng)的安全標(biāo)識(shí)號(hào) (SID)。
user 和 login 必須為 NULL、長(zhǎng)度為零的字符串 ('') 或不指定。 |
Update_One | 將當(dāng)前數(shù)據(jù)庫(kù)中指定的 user 鏈接到 login。login 必須已經(jīng)存在。必須指定 user 和 login。 |
[@UserNamePattern =] 'user'
是當(dāng)前數(shù)據(jù)庫(kù)中的 SQL Server 用戶的名稱。user 的數(shù)據(jù)類型為 sysname,默認(rèn)值為 NULL。sp_change_users_login 只能用于 SQL Server 登錄和用戶的安全帳戶;而不能用于 Microsoft Windows NT® 用戶。
[@LoginName =] 'login'
SQL Server 登錄的名稱。login 的數(shù)據(jù)類型為 sysname,默認(rèn)值為 NULL。
返回代碼值
0(成功)或 1(失敗)
結(jié)果集
列名 | 數(shù)據(jù)類型 | 描述 |
---|---|---|
UserName | sysname | 登錄名。 |
UserSID | varbinary(85) | 登錄安全標(biāo)識(shí)符。 |
注釋
使用此過(guò)程將當(dāng)前數(shù)據(jù)庫(kù)中用戶的安全帳戶鏈接到不同的登錄。如果用戶登錄已更改,則使用 sp_change_users_login 將用戶鏈接到新的登錄,而不會(huì)丟失用戶的權(quán)限。
login 不能為 sa,而 user 不能為 dbo、guest 或 INFORMATION_SCHEMA 用戶。
不能在用戶定義的事務(wù)中執(zhí)行 sp_change_users_login。
權(quán)限
任何 public 角色的成員均可執(zhí)行帶有 Report 選項(xiàng)的 sp_change_users_login。只有 sysadmin 固定服務(wù)器角色的成員才能指定 Auto_Fix 選項(xiàng)。只有 sysadmin 或 db_owner 角色的成員才能指定 Update_One 選項(xiàng)。
示例
A. 顯示登錄映射的當(dāng)前用戶的報(bào)告
下面的示例生成當(dāng)前數(shù)據(jù)庫(kù)中的用戶及其安全標(biāo)識(shí)符的報(bào)告。
EXEC sp_change_users_login 'Report'
B. 更改用戶的登錄
下面的示例更改 pubs 數(shù)據(jù)庫(kù)中的用戶 Mary 與現(xiàn)有登錄之間的鏈接,鏈接到新的登錄 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'
相關(guān)文章
SQL Server數(shù)據(jù)庫(kù)中偽列及偽列的含義詳解
這篇文章主要給大家介紹了關(guān)于SQL Server數(shù)據(jù)庫(kù)中偽列及偽列含義的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-09-09如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)
如何在SQLSERVER中快速有條件刪除海量數(shù)據(jù)...2006-09-09SQLServer 日期函數(shù)大全(小結(jié))
這篇文章主要介紹了SQLServer 日期函數(shù)大全(小結(jié)),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04SQL Server出現(xiàn)System.OutOfMemoryException異常的解決方法
這篇文章主要介紹了SQL Server出現(xiàn)System.OutOfMemoryException異常的解決方法,同時(shí)提供了微軟官方的解決方案,需要的朋友可以參考下2014-06-06SQLServer查詢某個(gè)時(shí)間段購(gòu)買過(guò)商品的所有用戶
這篇文章主要介紹了SQLServer查詢某個(gè)時(shí)間段購(gòu)買過(guò)商品的所有用戶,需要的朋友可以參考下2017-07-07SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串
這篇文章介紹了SQL Server一個(gè)字符串拆分多行顯示或者多行數(shù)據(jù)合并成一個(gè)字符串的方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-05-05sqlserver 復(fù)制表 復(fù)制數(shù)據(jù)庫(kù)存儲(chǔ)過(guò)程的方法
復(fù)制整個(gè)SqlServer數(shù)據(jù)庫(kù)的問(wèn)題的比較好的方法2008-02-02SqlServer2000+ 身份證合法校驗(yàn)函數(shù)的示例代碼
這篇文章主要介紹了SqlServer2000+ 身份證合法校驗(yàn)函數(shù),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05