更改數據庫對象全部者的方法

sp_changeobjectowner更改當前數據庫中對象的全部者。
  語法:
sp_changeobjectowner [ @objname = ] 'object' ,
[ @newowner = ] 'owner'參數[@objname =] '
  object'當前數據庫中現有的表、視圖或存儲過程的名稱。
  object 的數據類型爲 nvarchar(517),沒有默認值。object 可用現有對象全部者限定,格式爲:
existing_owner.object。[@newowner =] 'owner'
  即將成爲對象的新全部者的安全賬戶的名稱。
  owner 的數據類型爲 sysname,沒有默認值。owner 必須是當前數據庫中有效的 Microsoft® SQL Server™ 用戶或角色或 Microsoft Windows NT® 用戶或組。指定 Windows NT 用戶或組時,請指定 Windows NT 用戶或組在數據庫中已知的名稱(用 sp_grantdbaccess 添加)。返回代碼值0(成功)或 1(失敗)註釋對象全部者(或擁有對象的組或角色的成員)對對象有特殊的權限。
  對象全部者能夠執行任何與對象有關的 Transact-SQL 語句(例如 INSERT、UPDATE、DELETE、SELECT 或 EXECUTE),也能夠管理對象的權限。
  若是擁有對象的安全賬戶必需要除去,但同時要保留該對象,請使用 sp_changeobjectowner 更改對象全部者。
  該過程從對象中刪除全部現有權限。在運行 sp_changeobjectowner 以後,須要從新應用要保留的任何權限。因爲這個緣由,建議在運行 sp_changeobjectowner 以前,編寫現有權限的腳本。一旦更改了對象的全部權,可能要使用該腳本從新應用權限。在運行該腳本以前須要在權限腳本中修改對象全部者。有關編寫數據庫腳本的更多信息,請參見編寫數據庫文檔和腳本。 本文發表於[url]http://bianceng.cn[/url](編程入門)
  能夠使用 sp_changedbowner 更改數據庫的全部者。權限只有 sysadmin 固定服務器角色和 db_owner 固定數據庫角色成員,或既是 db_ddladmin 固定數據庫角色又是 db_securityadmin 固定數據庫角色的成員,才能執行 sp_changeobjectowner。
  示例下面的示例將 authors 表的全部者改成:
CorporateGeorgeW。EXEC sp_changeobjectowner'authors', 'CorporateGeorgeW'exec sp_changeobjectowner 'ychw.proc_Subject512_Function', 'dbo'
相關文章
相關標籤/搜索