碰到一个数据库下无法删除用户的情况,总是提示"该用户拥有对象,无法删除",最后老大过来解释后,发现原来在该用户下有几个表对象,用sql语句去改变那些表的用户的语句:
 sp_changeobjectowner 'can.WCMDocQuoteImage','dbo'
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'