sql2000中删除用户出现错误提示: 因为选定的用户拥有对象,所以无法除去该用户(转载)

【转】sql2000中删除用户出现错误提示: 因为选定的用户拥有对象,所以无法除去该用户(转载)

由于mssql200数据库的错误,我把一个原来的数据库还原到现在的sql上,此时我来到用户里面,想把还原过来的用户删除掉,结果却提示“ 因为选定的用户拥有对象,所以无法除去该用户 ”:

删除不了,我就准备把系统里的该用户添加到这个数据库上来看看可以不,却又提示这么一个错误(microsoft sql-dmo    窗口):

错误21002:[SQL-DMO]用户"liuhui"已经存在。

因 为业务要求,我又不能重新建立一个用户给它或换一个用户,该数据库只能被该用户使用,标准的规范的服务器格式不能打破,要不会带来以后维护的超级麻烦,没 办法求救google 和 baidu ,结果无所不知的他们让我失望了,没办法,只好请求一个经验丰富的朋友帮忙,问题解决了,该技术为不传之密,一般人我不告诉他:
1.打开企业管理器,展开服务器,右键点击本地服器,属性


打开sql server 属性(配置)窗口
2.选择常规窗口,将 自动开启sql server 代理选上:


确定

3.重复动作1.打开打开sql server 属性(配置)窗口,选择 服务器设置窗口:

允许对系统目录直接进行修改选上,确定。

4.展开数据库,看到数据库系统表 sysusers ,右键--打开表--返回所有行


5.选择应为还原而添加进来的用户,找到相关行,点右键删除




选择

在返回到用户列表,看看还有该用户没有,如果没有用户,我们在去sql的安全里面把该数据库对应的用户添加上去,我把liuhui添加上去了,测试网站没有问题了。

再返回动作3把选择上的 允许对系统目录直接进行修改去掉

使用下面这个方法也可以删除这个用户,把数据表里的所有者对象全部修改成dbo先在,现在在删除就已经没有问题了,

另外一种方法

今天在帮朋友弄一台服务器的时候当我需要删除一个数据库里的用户时,提示如下错误信息:
  "选定的用户拥有对象,所以无法除去该用户"
  如何解决呢?
  我试了网上提供的一些方法都不行,最后还是自己用SQL解决了些问题。
  1 在查询分析器里面选中出问题的数据库,然后输入:
  Exec sp_configure 'allow updates',1 --允许更新系统表。
  RECONFIGURE WITH OVERRIDE
  2.运行如下SQL语句:
  UPDATE sysobjects SET uid=1 --把数据库里所有的对象都归属到用户dbo
  3.执行如下SQL语句:
  Exec sp_configure 'allow updates',0 --关闭系统表更新
  RECONFIGURE WITH OVERRIDE
  4.删除数据库里的用户,再重新建立用户。
  从Google中知道了产生此问题的原因如下:
  MSSQL备份移植到另一服务器还原时容易遇到的问题……
  MSSQL备份移植到另一服务器还原时容易遇到的问题,尤其是从虚拟主机备份回来的数据库在本机还原的问题…
  会出现用SQL原来的用户名和密码无效的情况
  无法删除某一个系统表
  用sa连接做Select时提示表名无效
  无法删除原备份数据库中的用户名,提示“因为选定的用户拥有对象,所以无法除去该用户。”
  主要原因是原来的备份还原时保留了原用户的信息,导致产生孤立用户……(

posted @ 2012-11-06 16:58  程序员徐坤  阅读(857)  评论(0编辑  收藏  举报