oracle数据库升级导致的数据库对象不可用或无效解决办法

前端时间,公司集体升级数据库版本,由于数据库的版本与服务器版本不对应导致升级失败,而我又没有提前对服务器进行数据备份,升级失败后导致,数据库无法使用,虽然可以连接进行查询查询操作,但是无法进行复杂的数据库操作(比如数据导出操作,表结构修改。。。),通过 

selectobject_type,object_id,object_name  

from user_objects 

where status='INVALID' order byobject_type  查询发现数据库中存在了大约8000多无效的数据库对象,使用utlrp.sql脚本更新数据库对象状态执行也会出现异常。经过不断的研究,确认应该是数据库软件内部的初始化构建的字典视图、存储过程等等数据库自身使用的对象启动失败造成的,所以使用下面几个脚本进行数据库字典视图的初始化操作。

 catalog.sql:  

创建数据字典视图

catblock.sql: 

创建ORACLE中一些锁机制相关的视图

catproc.sql:  

创建ORACLE一些存储过程和包

catoctk.sql:  

创建需要使用PL/ SQL加密工具的接口

owminst.plb:  

安装SQL*Plus的表PRODUCT_USER_PROFILE, 好像是与数据仓库有关的东西.

 

所有的脚本执行完毕后,我查询发现还是有不少的数据库对象不可用,但是操作发现正常的数据库的操作已经不受影响了,如何你也碰到类型的大批量的数据库对象无效的情况,不妨也试一试!

 

最后说句废话:数据库的升级一定要打补丁。血的教训!!


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值