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

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'  




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值