SQL数据库恢复后出现对象名无效(SQL Server备份还原时造成孤立用户的解决方案)
2011-04-18 09:38
以碰到这个烦人的问题,恢复的时候自带了个用户,但怎么也删除不掉,select * from 表名 说对象无效,要select * from 用户.表名
 
这样才行,晕,,要将用户改成dbo为所有者就可以了
 
SQL对象名无效的解决方法  (网上方法1)
 
个人觉得还蛮全,但最后一点不行,所以在后面有所补充

产生SQL对象名无效的问题大多原因是由于数据迁移导致的,下面我们给出解决方法.

在使用数据库的过程中,经常会遇到数据库迁移或者数据迁移的问题,或者有突然的数据库损坏,这时需要从数据库的备份中直接恢复。但是,此时会出现问题,这里说明几种常见问题的解决方法。
一、孤立用户的问题
比如,以前的数据库的很多表是用户test建立的,但是当我们恢复数据库后,test用户此时就成了孤立用户,没有与之对应的登陆用户名,哪怕你建立了一个test登录用户名,而且是以前的用户密码,用该用户登录后同样没办法操作以前属于test的用户表。
这个问题有两种办法解决。
先说解决的前提条件。
首先,要用备份文件还原数据库,我们这里的数据库名为testdb,里面有属于用户test的用户表。这个很容易了操作了,不多讲了,在企业管理器中很方便可以恢复。恢复后,就产生了孤立用户test。
然后,用sa用户或者具有DBA权限的用户登录,创建一个test数据库登录用户,密码随便设置了,也可以和以前的保持一致。我们用它来对应孤立的test用户。
下面就有两种操作方法了,第一种就是改变对象的属主,第二种就是使登录用户和数据库的孤立用户对应起来。先说第一种方法。
1、修改对象属主
就是将原本属于数据库用户test的用户表,修改为属于dbo的用户表;然后修改test登录用户的数据库为testdb,就可以直接使用test登录用户登录后对该数据库进行操作了。
使用的存储过程
sp_changeobjectowner [ @objname = ] 'object' , [ @newowner = ] 'owner'
参数说明
[ @objname = ] 'object'
当前数据库中现有表、视图、用户定义函数或存储过程的名称。object 是 nvarchar(776),没有默认值。如果架构及其所有者具有相同的名称,则 object 可由现有对象所有者限定,格式为 existing_owner.object。
[ @newowner=] 'owner '
将成为对象的新所有者的安全帐户的名称。owner 的数据类型为 sysname,没有默认值。owner 必须是可访问当前数据库的有效数据库用户、服务器角色、Microsoft Windows 登录名或 Windows 组。如果新所有者是没有对应数据库级主体的 Windows 用户或 Windows 组,则将创建数据库用户。
实例:
以下示例将 authors 表的所有者更改为 dbo。
EXEC sp_changeobjectowner 'authors', 'dbo';
GO
        这个方法有个最大的缺点就是,当表的数量非常多,而且还有存储过程或者触发器之类的修改起来会非常麻烦,需要一个一个修改,所以,不提倡使用。现在网上有一个批量修改的存储过程,大家可以找一下,这里就不说了,而是教大家一个更简单的。
        2、使登录用户和数据库的孤立用户对应起来
        其实我们建立了同样名称的数据库登录用户后,数据库中的表我们照样不能使用时因为sid的不同,就是系统登录表和数据库用户表中的用户名相同,单是sid 字段,数据库中的还是以前旧系统的sid值,所以我们就要把它对应成我们新建的,数据库靠sid来识别用户。
        这里可以使用存储过程sp_change_users_login。它有三种动作,分别是report,update_one和auto_fix。
        运行sp_change_users_login 'report',系统会列出当前数据库的孤立用户数。
        我们只需要选择当前数据库为testdb,然后运行
        sp_change_users_login 'update_one','test','test'
        系统就会提示修复了一个孤立用户。
        如果没有建立test的登录用户,还可以用
sp_change_users_login 'Auto_Fix', 'test', NULL, 'testpassword'
来创建一个登录用户名为test,密码为testpassword的用户与之对应。
       
好了,到这里通常情况下,数据库对象得到访问问题已经解决了。如果有多个数据库中有同一个用户的数据表,只需要选择不同的数据库,执行update_one的那个就行了。

二、对象名 ‘xxxx’ 无效的问题

这里可能会有人遇到对象名 ‘xxxx’无效的问题。系统表却不会产生这个问题,而用户表还要加上用户名,然后是表明才能访问,比如select * from author,会说对象名 author 无效,而用select * from test.author就可以访问,这个是用户首选身份的问题。

解决很简单,就是察看test登录用户是否具有dba的权限或者系统管理的权限,有的话去掉就行了。
        因为如果用户有dba身份,那么它登陆后的默认表空间是dbo的系统表空间,所以去掉了之后,就会以正常的test表空间访问数据表了。

补充:

--执行这个语句,就可以把当前库的所有表的所有者改为dbo
exec sp_msforeachtable 'sp_changeobjectowner ''?'', ''dbo'''

--如果是要用户表/存储过程/视图/触发器/自定义函数一齐改,则用游标(不要理会错误提示)
declare tb cursor local for
select 'sp_changeobjectowner ''['+replace(user_name(uid),']',']]')+'].['+replace(name,']',']]')+']'',''dbo'''
from sysobjects
where xtype in('U','V','P','TR','FN','IF','TF') and status>=0
open tb
declare @s nvarchar(4000)
fetch tb into @s
while @@fetch_status=0
begin
exec(@s)
fetch tb into @s
end
close tb
deallocate tb
go

以SA登陆查询分析器 ,选中你要的数据库
执行存储过程
执行exec Changename ‘原所有者','dbo'
或exec Changename ‘dbo,'数据库所有者'

修改MS SQL表用户属性的命令

可以用exec sp_changeobjectowner ‘dataname.数据表','dbo' 把表或存储过程中的所有者都改成dbo

SQL数据库恢复后出现对象名无效(SQL Server备份还原时造成孤立用户的解决方案相关推荐

  1. 数据库对象名无效 解决方法总结

    在数据库里面新建表后显示对象名无效,但是在表中能看见,就是无法引用.(强迫症.看着下划线是一排红色的.不爽).重启sql服务也没有用. 暴力解决方法::关闭SQL管理器,再重新打开.(红色下划线不见了 ...

  2. sql 数据库 恢复 全攻略

    数据库恢复可以分如下几种情况 1.数据库日志保存完整的时候 Log Explorer http://www.ttdown.com/SoftDown.asp?ID=14562 http://js.fix ...

  3. SQL对象名无效怎么办法 华骨龙

      使用sqlserver数据库时,产生SQL对象名无效的问题一般是以下两种常见原因,下面根据不同的原因给出解决方法. 原因一:数据库做过迁移,新数据库的对象所有者名称不同造成 数据库做了迁移后,一般 ...

  4. 前5名最佳SQL数据库恢复软件

    导言 在本文中,我们将研究最优秀的5种SQL数据库恢复软件,这些软件将帮助我们从损坏的.mdf和.ndf文件中恢复和恢复数据库.在这里,我将教您如何操作该软件,以及它们将如何为我们恢复文件. 前5名最 ...

  5. 深圳坐标软件 SQL数据库 复制 报错 MS-DOS 功能无效 上读取失败 1(函数不正确) 恢复实践

    坐标软件 SQL数据库 复制 报错 MS-DOS 功能无效 上读取失败 1(函数不正确) 恢复实践 接到文件,立即组织进行分析工作,发现 select * from sysobjects  --系统表 ...

  6. sql server 对象名无效的解决方法

    sql server 对象名无效的解决方法 参考文章: (1)sql server 对象名无效的解决方法 (2)https://www.cnblogs.com/meetcomet/p/3477937. ...

  7. 数据库已经插入表名但是显示对象名无效

    SQL SERVER 已经插入表名,select 可以查出数据,但是显示对象名无效 问题 解决:试试刷新本地缓存,方法--菜单栏>编辑>intelliSense>刷新本地缓存.

  8. C# 对象名无效 问题

    相信有些人访问数据库会出现对象名无效的问题,网上也给出了许多的解决方案,搞了一晚上才查出原因,各种伤不起,现在说一下心得,让后来的学弟学妹们少走点弯路: 实行检查三步走策略,相信三步走之后一般会解决问 ...

  9. 服务器系统坏了如何导出sql数据库,服务器系统坏了如何导出sql数据库

    服务器系统坏了如何导出sql数据库 内容精选 换一换 PostgreSQL支持逻辑备份.您可使用pg_dump逻辑备份功能,导出备份文件,再通过psql导入到RDS中,实现将PostgreSQL的数据 ...

最新文章

  1. Overleaf-LaTex表格制作
  2. 数据结构(队列实现篇)
  3. Failed to set NvVAD endpoint as default Audio endpoint [0]
  4. 【LDA学习系列】MCMC之Metropolis-Hastings采样算法python代码理解
  5. 监理单位的组织与规划
  6. NLP 命名实体识别
  7. 让Win32窗口程序拥有控制台窗口
  8. Git 企业中常用分支管理策略
  9. 【若依(ruoyi)】Bootstrap-Table的使用
  10. iPhone XI Max带壳渲染图曝光:依然刘海屏 后置“浴霸”三摄实锤
  11. linux 2.6 内核的移植
  12. css3 混合,css3混合模式
  13. python展开列表代码_python列表(list)用法示例代码
  14. Unity 清理注册表和临时文件
  15. Mysql的分组函数
  16. Web APIs day6 | 正则阶段案例
  17. 【活动回顾】机智云亮相2020中国移动全球伙伴合作大会
  18. 电脑怎么找到tomcat端口_查看tomcat端口号(怎么看tomcat的端口号)
  19. matlab中怎么画冲激函数,matlab怎么画冲激函数波形,这些知识你不一定知道
  20. Zip、Rar文件解压

热门文章

  1. MooTools Class 使用、继承详解
  2. Apache 2.2 + Php 5.1 安装问题解决[原创]
  3. NYOJ 5177 疯牛(最大化最小值 二分搜索)
  4. hdu 4831(线段树---待解决)
  5. php笔记之表单验证
  6. NYOJ 119 士兵杀敌(三)
  7. ABAP 7.53 中的ABAP SQL(原Open SQL)新特性
  8. 文件夹获取管理员权限脚本
  9. AngularJS实战之Controller之间的通信
  10. C#基础知识 课堂笔记 上