sqlserver 无法删除用户 提示"该用户拥有对象,无法删除"

sqlserver 无法删除用户 提示"该用户拥有对象,无法删除",第1张

概述sqlserver 无法删除用户碰到一个数据库下无法删除用户的情况,总是提示"该用户拥有对象,无法删除",最后老大过来解释后,发现原来在该用户下有几个表对象,用sql语句去改变那些表的用户的语句: sp_changeobjectowner 'can.WCMDocQuoteImage','dbo' 注意,这里can是要删除的用户,同时它拥有对象--WCMDocQuoteImage,最后我们改变成让d

sqlserver 无法删除用户碰到一个数据库下无法删除用户的情况,总是提示"该用户拥有对象,无法删除",最后老大过来解释后,发现原来在该用户下有几个表对象,用SQL语句去改变那些表的用户的语句:

sp_changeobjectowner 'can.WCMDocQuoteImage','dbo'

注意,这里can是要删除的用户,同时它拥有对象--WCMDocQuoteImage,最后我们改变成让dbo拥有这个对象。


通过执行   sp_addlogin,把登录   janetl   改名为   dbo。     

sp_addlogin   'janetl','dbo'   

备份数据库。在本例中,备份   northwind。     
BACKUP   DATABASE   northwind   TO   disK   =   'c:\mssql\backup\northwnd'   


除去刚刚备份的数据库。     
DROP   DATABASE   northwind   

除去登录。     
sp_droplogin   'janetl'   


还原备份的数据库。     
RESTORE   DATABASE   northwind   FROM   disK   =   'c:\mssql\backup\northwnd'   


janetl   登录不能访问   northwind   数据库,除非允许   guest   登录。尽管   janetl   登录已经删除,它仍然(作为一个孤立行)显示在   sysusers   表中:   
USE   northwind   SELECT   *   FROM   sysusers   WHERE   name   =   'janetl'   


解决孤立用户问题     
    
用   sp_addlogin   添加一个临时登录。为孤立用户指定安全标识符   (SID)(从   sysusers)。     
sp_addlogin   @loginame   =   'nancyd',@sID   =   0x32C864A70427D211B4DD00104B9E8A00   


 用   sp_dropalias   除去属于别名   SID   的临时别名。     
sp_dropalias   'nancyd'   

用   sp_dropuser   除去原始用户(即现在的孤立用户)。     
sp_dropuser   'janetl'   

用   sp_dropuser   除去原始登录。     
sp_droplogin   'nancyd'  
总结

以上是内存溢出为你收集整理的sqlserver 无法删除用户 提示"该用户拥有对象,无法删除"全部内容,希望文章能够帮你解决sqlserver 无法删除用户 提示"该用户拥有对象,无法删除"所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/sjk/1177951.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-02
下一篇 2022-06-02

发表评论

登录后才能评论

评论列表(0条)

保存