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'  




你可能感兴趣的:(数据库资料,MS,SQL,Server,数据库报错)