`
raisun_1988
  • 浏览: 113813 次
  • 性别: Icon_minigender_1
  • 来自: 长沙
社区版块
存档分类
最新评论

SQL对象名无效的解决

    博客分类:
  • .Net
SQL 
阅读更多

SQL对象名无效的解决方法 http://www.itpob.cn/

     产生SQL对象名无效的问题大多原因是由于数据迁移导致的,下面我们给出解决方法. 在使用数据库的过程中,经常会遇到数据库迁移或者数据迁移的问题,或者有突然的数据库损坏,这时需要从数据库的备份中直接恢复。但是,此时会出现问题,这里说明几种常见问题的解决方法。

一、孤立用户的问题 比如,以前的数据库的很多表是用户test建立的,但是当我们恢复数据库后,test用户此时就成了孤立用户,没有与之对应的登陆用户名,哪怕你建立了一个test登录用户名,而且是以前的用户密码,用该用户登录后同样没办法操作以前属于test的用户表。

           这个问题有两种办法解决。 先说解决的前提条件。 首先,要用备份文件还原数据库,我们这里的数据库名为testdb,里面有属于用户test的用户表。这个很容易了操作了,不多讲了,在企业管理器中很方便可以恢复。恢复后,就产生了孤立用户test。然后,用sa用户或者具有DBA权限的用户登录,创建一个test数据库登录用户,密码随便设置了,也可以和以前的保持一致。我们用它来对应孤立的test用户。

     使登录用户和数据库的孤立用户对应起来 其实我们建立了同样名称的数据库登录用户后,数据库中的表我们照样不能使用时因为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的那个就行了。

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

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

方法二: 将所有test所有表设置为dbo就OK了

执行语句:exec sp_msforeachtable "sp_changeobjectowner '?','dbo'"

 

本文来自http://www.itpob.cn/

分享到:
评论

相关推荐

    SQL对象名无效的解决方法

    SQL对象名无效的解决方法,很好很强大,希望对网友有帮助

    讲解孤立用户和对象名无效问题的解决方法

    讲解孤立用户和对象名无效问题的解决方法讲解孤立用户和对象名无效问题的解决方法

    sql2005转到sql2000时所遇到出错问题时的解决方法

    sql2005转到sql2000时所遇到出错问题时的解决方法 ...对象名 'sys.objects ' 无效。 对象名 'sys.foreign_keys' 无效。 我知道sys.foreign_keys对应SQL2000里面是sysforeignkeys,但我改了的话有出现其它两报错,

    java连接sql server端口错误问题解决

    java连接sql server端口错误

    RedGate SQL Prompt Pro.5.1.8.2 破解完整

    SQL Server中非常好用的插件,可以大大地方便SQL脚本的编写(比如自动提示完成关键字或者对象名、为脚本对象前加上架构信息(dbo.)、自定义命令插入脚本块等) 官方解释(使用机器翻译): SQL Server开发人员和...

    DbHelperSQL类文件(asp.net最基本方法)

    DbHelperSQL类,包括对数据库操作的所有方法,如公用方法、执行简单SQL语句、执行带参数的SQL语句、存储过程操作等。

    sqlserver 实现 行转列 split 分割的函数

    sqlserver 实现 行转列 split 分割的函数,具体使用方法写有在文件里。

    Windows 2008 R2 环境 配置安装SQL 2008和金蝶K/3V12.3

    Windows 2008 R2 环境 配置安装SQL 2008和金蝶K/3V12.3教程

    Microsoft SQL Server 2005 Express Edition SP3

    ”若要解决此问题,请使用“添加或删除程序”卸载 SQL 本机客户端。对于群集,请从所有节点中卸载 SQL 本机客户端。然后,再次运行 SQL Server 安装程序。 [顶部] 3.2 系统配置检查器失败并显示“性能监视器计数器...

    RedGate SQL.Prompt.Pro.5.1.8.2 cracked

    SQL Server中非常好用的插件,可以大大地方便SQL脚本的编写(比如自动提示完成关键字或者对象名、为脚本对象前加上架构信息(dbo.)、自定义命令插入脚本块等) 官方解释(使用机器翻译): SQL Server开发人员和...

    SQL Server 2008编程入门经典(第3版)

    5.1 SQLserver中的对象名 5.1.1 模式名 5.1.2 数据库名 5.1.3 通过服务器命名 5.1.4 回顾默认值 5.2 CReATE语句 5.2.1 CREATEDATAASE 5.2.2 CREATETABLE 5.3 ALTER语句 5.3.1 AITERDATABASE 5.3.2 ALTERTABLE 5.4 ...

    解密SQL2008加密过的存储过程方法及脚本

    解密sql2008 下加密的存储过程脚本, 4.0版本存储过程,解决存储过程过长解密出来是空白的问题 解密2008 下加密的存储过程、触发器等

    SQL.Server.2008编程入门经典(第3版).part2.rar

    5.1 SQLserver中的对象名 5.1.1 模式名 5.1.2 数据库名 5.1.3 通过服务器命名 5.1.4 回顾默认值 5.2 CReATE语句 5.2.1 CREATEDATAASE 5.2.2 CREATETABLE 5.3 ALTER语句 5.3.1 AITERDATABASE 5.3.2 ALTERTABLE 5.4 ...

    SQL.Server.2008编程入门经典(第3版).part1.rar

    5.1 SQLserver中的对象名 5.1.1 模式名 5.1.2 数据库名 5.1.3 通过服务器命名 5.1.4 回顾默认值 5.2 CReATE语句 5.2.1 CREATEDATAASE 5.2.2 CREATETABLE 5.3 ALTER语句 5.3.1 AITERDATABASE 5.3.2 ALTERTABLE 5.4 ...

    pl/sql操作手册

    8. 创建与修改非 PL/SQL 对象............................................................................................................51 8.1 表定义编辑器.................................................

    ob9数据库查看工具中文版.rar

    通过对象名和脚本的全文查询可以进行一些复杂的包含查询。进一步,通过登录一些经常使用的对象到Workspace,这样连对象查询本身的作业可以不要。存储过程创建功能通过工具的全屏幕编辑器,可以创建和编辑过程,函数...

    SQL sever 实训

    SQL sever 2008 Rar! ?s X祕BwL0 17240671-1.sql ?年3月9日 --1.查询course表的所有信息(所有行所有列) USE Xk GO SELECT * FROM Course --有哪些种类的选修课?学分是多少 USE XK GO SELECT Kind,Credit FROM ...

    SQL Server 2016里的sys.dm_exec_input_buffer的问题

    我们都知道DBCC命令有点尴尬,因为你不能在T-SQL查询里调用它们,你也不能关联它们的输出到其它DMV/DMF。例如你想为每个用户会话返回最后一个执行的SQL语句…. sys.dm_exec_input_buffer 在SQL Server 2016里,...

    chr2sql:CHR2到SQL的转换

    CHR2转SQL转换器该库通过将规则转换为SQL脚本集来实现约束处理规则(CHR)求解器。 因此,求解器可以使用约束集。 语法类似于Peter Van Weert在“扩展和优化约束处理规则的编译”(又名CHRv2)中定义的语法。 CHR...

Global site tag (gtag.js) - Google Analytics