热搜:

MSSQL中删除用户时 数据库主体在该数据库存中拥有架构 无法删除

2013-05-02 15:20:27文章来源:点点软件园热度:0

更多

在ms sql2005 下面删除一个数据库的用户的时候提示更多最新IT资讯尽在金顺软件园http://www.jinshun168.com/

"数据库主体在该数据库中拥有架构,无法删除"

的错误解决方案
 
1、在 安全性 -> 架构 下面看有没有该用户存在,如果有就删除
 
再试试在用户下面看能不能把该用户删掉,如果不行就用下面的文法
 
运行下SQL语句
ALTER AUTHORIZATION ON SCHEMA::db_owner TO dbo; 
 
--然后手动删除就可以了。
 

因为选定的用户拥有对象,所以无法除去该用户"解决方法
use 你的库名
go

declare tb cursor local
for
select 'sp_changeobjectowner '
+quotename(
+quotename(user_name(uid))
+'.'+quotename(name),'''')
+',''dbo'''
from sysobjects 
where objectproperty(id,N'isusertable')=1
and uid<>user_id('dbo')
declare @s nvarchar(4000)
open tb
fetch tb into @s
while @@fetch_status=0
begin
exec(@s)
fetch tb into @s
end
close tb
deallocate tb
第三

方法一(华夏互联专业技术提示:因为涉及更改数据库存储过程,强制删除法不推荐)
首先你需要做的第一件事
企业管理器-〉选择服务器-〉属性-〉服务器设置-〉挑上允许对系统目录。。。-〉确定
第二步
找到你的数据库找到sysusers表那你以前的用户删除
第三步回去吧属***值改回来
第四部重建用户即可

方法二

对mssql出现选定的用户拥有对象而无法删除的处理

--将下面的代码在查询分析器中执行,修改修改库名

use 你的库名
go

declare tb cursor local
for
select 'sp_changeobjectowner '
+quotename(
+quotename(user_name(uid))
+'.'+quotename(name),'''')
+',''dbo'''
from sysobjects 
where objectproperty(id,N'isusertable')=1
and uid<>user_id('dbo')
declare @s nvarchar(4000)
open tb
fetch tb into @s
while @@fetch_status=0
begin
exec(@s)
fetch tb into @s
end
close tb
deallocate tb




MSSQL备份移植到另一服务器还原时容易遇到的问题……
MSSQL备份移植到另一服务器还原时容易遇到的问题,尤其是从虚拟主机备份回来的数据库在本机还原的问题…

会出现用SQL原来的用户名和密码无效的情况 
无法删除某一个系统表 
用sa连接做Select时提示表名无效 
无法删除原备份数据库中的用户名,提示“因为选定的用户拥有对象,所以无法除去该用户。”
主要原因是原来的备份还原时保留了原用户的信息,导致产生孤立用户……

这时候需要用sp_changeobjectowner 将对象的所有关系更改到另一个用户上,既更改数据库对象的所有者。

格式:

sp_changeobjectowner [@objectname =] 'object', [@newowner =] 'owner' 
例子 在查询分析器中录入:

sp_changeobjectowner 'web102101.tablename', 'dbo'
依次将所有的所属用户都改为dbo,然后现在数据库的用户中把孤立用户删除,再到安全中删除登陆信息。

并可以再依次创建新用户了

以上,就是金顺软件园小编给大家带来的MSSQL中删除用户时 数据库主体在该数据库存中拥有架构 无法删除全部内容,希望对大家有所帮助!

上一篇SharePoint Server 2010中的PowerPivot多维数据源下一篇yy盒子变声器怎么用?yy盒子字幕器怎么用?yy盒子音效器怎么用?
编辑:点点小编