sp_dropuser (Transact-SQL)

適用于:SQL Server

從目前資料庫移除資料庫使用者。 sp_dropuser提供與舊版SQL Server的相容性。

重要

未來的 Microsoft SQL Server 版本將移除這項功能。 請避免在新的開發工作中使用這項功能,並規劃修改目前使用這項功能的應用程式。 請改用 DROP USER

Transact-SQL 語法慣例

語法

  
sp_dropuser [ @name_in_db = ] 'user'  

引數

[ @name_in_db = ] 'user' 這是要移除的使用者名稱。 usersysname,沒有預設值。 使用者 必須存在於目前資料庫中。 在指定 Windows 登入時,請使用該登入在資料庫所用的名稱。

傳回碼值

0 (成功) 或 1 (失敗)

備註

sp_dropuser 會執行 sp_revokedbaccess ,以從目前的資料庫移除使用者。

使用 sp_helpuser 顯示可從目前資料庫移除的使用者名稱清單。

移除資料庫使用者時,也會一併移除該使用者的任何別名。 如果該使用者擁有與該使用者同名的空結構描述,則會卸除結構描述。 如果該使用者擁有資料庫中任何其他安全性實體,則不會卸除使用者。 物件的擁有權必須先傳送到另一個主體。 如需詳細資訊,請參閱 ALTER AUTHORIZATION (Transact-SQL) 。 移除資料庫使用者時,也會自動移除與該使用者相關聯的權限,並且從它所屬的任何資料庫角色移除該使用者。

sp_dropuser無法用來從mastertempdb資料庫中移除資料庫擁有者, (dbo) INFORMATION_SCHEMA使用者或來賓使用者。 在非系統資料庫中, EXEC sp_dropuser 'guest' 將會撤銷使用者 來賓的 CONNECT 許可權。 但是使用者本身不會被卸除。

sp_dropuser 無法在使用者定義交易內執行。

權限

需要資料庫的 ALTER ANY USER 權限。

範例

下列範例會從目前資料庫移除使用者 Albert

EXEC sp_dropuser 'Albert';  
GO  

另請參閱

安全性預存程序 (Transact-SQL)
sp_grantdbaccess (Transact-SQL)
DROP USER (Transact-SQL)
sp_revokedbaccess (Transact-SQL)
系統預存程序 (Transact-SQL)