MSSQL中删除用户时数据库主体在该数据库存中拥有
导读:1建站知识在ms sql2005 下面删除一个数据库的用户的时候提示 数据库主体在该数据库中拥有架构,无法删除的错误解决方案seo网站优化网站seo优化课程。
在ms sql2005 下面删除一个数据库的用户的时候提示 "数据库主体在该数据库中拥有架构,无法删除" 的错误解决方案1、在 安全性 -> 架构 下面看有没有该用户存在,如果有就删除再试试在用户下面看能不能把该用户删掉,如果不行就用下面的文法运行下SQL语句ALTER AUTHORIZATION ON SCHEMA::db_owner TO dbo;
--然后手动删除就可以了。因为选定的用户拥有对象,所以无法除去该用户"解决方法
复制代码 代码如下:
use 你的库名go
declare tb cursor localforselect 'sp_changeobjectowner '+quotename(+quotename(user_name(uid))+'.'+quotename(name),'''')+',''dbo'''from sysobjects where objectproperty(id,N'isusertable')=1and uid<>user_id('dbo')declare @s nvarchar(4000)open tbfetch tb into @swhile @@fetch_status=0beginexec(@s)fetch tb into @sendclose tbdeallocate tb
第三
方法一(华夏互联专业技术提示:因为涉及更改数据库存储过程,强制删除法不推荐)首先你需要做的第一件事企业管理器-〉选择服务器-〉属性-〉服务器设置-〉挑上允许对系统目录。。。-〉确定第二步找到你的数据库找到sysusers表那你以前的用户删除第三步回去吧属***值改回来第四部重建用户即可
方法二
对mssql出现选定的用户拥有对象而无法删除的处理
--将下面的代码在查询分析器中执行,修改修改库名
复制代码 代码如下:
use 你的库名go
declare tb cursor localforselect 'sp_changeobjectowner '+quotename(+quotename(user_name(uid))+'.'+quotename(name),'''')+',''dbo'''from sysobjects where objectproperty(网站推广优化seoid,N'isusertable')=1and uid<>user_id('dbo')declare @s nvarchar(4000)open tbfetch tb into @swhile @@fetch_status=0beginexec(@s)fetch tb into @sendclose tbdeallocate tb
MSSQL备份移植到另一服务器还原时容易遇到的问题……MSSQL备份移植到另一服务器还原时容易遇到的问题,尤其是从虚拟主机备份回来的数据库在本机还原的问题…
会出现用SQL原来的用户名和密码无效的情况 无法删除某一个系统表 用sa连接做Select时提示表名无效 无法删除原备份数据库中的用户名,提示“因为选定的用户拥有对象,所以无法除去该用户。”主要原因是原来的备份还原时保留了原用户的信息,导致产生孤立用户……
这时候需要用sp_changeobjectowner 将对象的所有关系更改到另一个用户上,既更改数据库对象的所有者。
格式:
sp_changeobjectowner [@objectname =] 'object', [@newowner =] 'owner'
例子 在查询分析器中录入:
声明: 本文由我的SEOUC技术文章主页发布于:2023-05-21 ,文章MSSQL中删除用户时数据库主体在该数据库存中拥有主要讲述架构,主体,SQL网站建设源码以及服务器配置搭建相关技术文章。转载请保留链接: https://www.seouc.com/article/web_3909.html