当前位置: 首页 > news >正文

故障处理:access$表在数据库丢失的恢复

我们的文章会在微信公众号IT民工的龙马人生和博客网站( www.htz.pw )同步更新 ,欢迎关注收藏,也欢迎大家转载,但是请在文章开始地方标注文章出处,谢谢!
由于博客中有大量代码,通过页面浏览效果更佳。

故障处理:access$表在数据库丢失的恢复

下面是测试一把access$基表丢失的恢复方法

欢迎大家加入ORACLE超级群:17115662 免费解决各种ORACLE问题,以后BLOG将迁移到http://www.htz.pw

1,数据库版本

www.htz.pw > select * from v$version;BANNER——————————————————————————–Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 – 64bit ProductionPL/SQL Release 11.2.0.3.0 – ProductionCORE    11.2.0.3.0      ProductionTNS for Linux: Version 11.2.0.3.0 – ProductionNLSRTL Version 11.2.0.3.0 – Production

2,启动报错

www.htz.pw > startup forceORACLE instance started.Total System Global Area  237998080 bytesFixed Size                  2227216 bytesVariable Size             197133296 bytesDatabase Buffers           33554432 bytesRedo Buffers                5083136 bytesDatabase mounted.ORA-01092: ORACLE instance terminated. Disconnection forcedORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not existProcess ID: 5599Session ID: 1 Serial number: 5

alert下面报这个错误

这里报递归的SQL出现错误,原因表不存在。下面alert中的日志内容

Completed redo scanread 90 KB redo, 65 data blocks need recoveryStarted redo application atThread 1: logseq 89, block 76381Recovery of Online Redo Log: Thread 1 Group 2 Seq 89 Reading mem 0Mem# 0: /oracle/app/oracle/oradata/orcl1123/redo02.logCompleted redo application of 0.06MBCompleted crash recovery atThread 1: logseq 89, block 76561, scn 306209665 data blocks read, 65 data blocks written, 90 redo k-bytes readThread 1 advanced to log sequence 90 (thread open)Thread 1 opened at log sequence 90Current log# 3 seq# 90 mem# 0: /oracle/app/oracle/oradata/orcl1123/redo03.logSuccessful open of redo thread 1MTTR advisory is disabled because FAST_START_MTTR_TARGET is not setSMON: enabling cache recoveryErrors in file /oracle/app/oracle/diag/rdbms/orcl1123/orcl1123/trace/orcl1123_ora_5599.trc:ORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not existErrors in file /oracle/app/oracle/diag/rdbms/orcl1123/orcl1123/trace/orcl1123_ora_5599.trc:ORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not existError 704 happened during db open, shutting down databaseUSER (ospid: 5599): terminating the instance due to error 704Instance terminated by USER, pid = 5599ORA-1092 signalled during: ALTER DATABASE OPEN…opiodr aborting process unknown ospid (5599) as a result of ORA-1092Tue Jun 10 20:41:24 2014ORA-1092 : opitsk aborting processTue Jun 10 20:41:39 2014Starting ORACLE instance (normal)

下面通过10046的方法来实现具体在那条语句报错

[oracle@www.htz.pw sql]$sqlplus / as sysdbaSQL*Plus: Release 11.2.0.3.0 Production on Tue Jun 10 20:41:37 2014Copyright (c) 1982, 2011, Oracle.  All rights reserved.Connected to an idle instance.www.htz.pw > startup mount;ORACLE instance started.Total System Global Area  237998080 bytesFixed Size                  2227216 bytesVariable Size             197133296 bytesDatabase Buffers           33554432 bytesRedo Buffers                5083136 bytesDatabase mounted.www.htz.pw > oradebug setmypidStatement processed.www.htz.pw > oradebug event 10046 trace name context forever,level 12;Statement processed.www.htz.pw > oradebug tracefile_name;/oracle/app/oracle/diag/rdbms/orcl1123/orcl1123/trace/orcl1123_ora_5691.trcwww.htz.pw > alter database open;alter database open*ERROR at line 1:ORA-01092: ORACLE instance terminated. Disconnection forcedORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not existProcess ID: 5691Session ID: 1 Serial number: 5

这里可以看到是表access$表不存在

PARSE ERROR #182956478584:len=56 dep=1 uid=0 oct=3 lid=0 tim=1402404227784268 err=942select order#,columns,types from access$ where d_obj#=:1ORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not existORA-00704: bootstrap process failureORA-00604: error occurred at recursive SQL level 1ORA-00942: table or view does not exist*** 2014-06-10 20:43:47.784USER (ospid: 5691): terminating the instance due to error 704EXEC #182936776088:c=152978,e=465517,p=58,cr=764,cu=0,mis=0,r=0,dep=0,og=1,plh=0,tim=1402404227824845ERROR #182936776088:err=1092 tim=1402404227824898

3,重建access$基表

建议的办法很简单,重启到数据库到upgrade模式,重建基表就可以了。

create table access$                                         /* access table */( d_obj#        number not null,                  /* dependent object number */order#        number not null,                  /* dependency order number */columns       raw("M_BVCO"),                /* list of cols for this entry */types         number not null)                             /* access types */storage (initial 10k next 100k maxextents unlimited pctincrease 0)/create index i_access1 onaccess$(d_obj#, order#)storage (initial 10k next 100k maxextents unlimited pctincrease 0)/www.htz.pw > create table access$                                         /* access table */2  ( d_obj#        number not null,                  /* dependent object number */3    order#        number not null,                  /* dependency order number */4    columns       raw("M_BVCO"),                /* list of cols for this entry */5    types         number not null)                             /* access types */6    storage (initial 10k next 100k maxextents unlimited pctincrease 0)7  /columns       raw("M_BVCO"),                /* list of cols for this entry */*ERROR at line 4:ORA-00910: specified length too long for its datatype

在其它相同的版本看到这个是126,但是不知道为什么从脚本弄出来的是一个字符串

SQL> desc access$;Name                                      Null?    Type—————————————– ——– —————————-D_OBJ#                                    NOT NULL NUMBERORDER#                                    NOT NULL NUMBERCOLUMNS                                            RAW(126)TYPES                                     NOT NULL NUMBERcreate table access$                                         /* access table */( d_obj#        number not null,                  /* dependent object number */order#        number not null,                  /* dependency order number */columns       raw(126),                /* list of cols for this entry */types         number not null)                             /* access types */storage (initial 10k next 100k maxextents unlimited pctincrease 0)/www.htz.pw > create table access$                                         /* access table */2  ( d_obj#        number not null,                  /* dependent object number */3    order#        number not null,                  /* dependency order number */4    columns       raw(126),                /* list of cols for this entry */5    types         number not null)                             /* access types */6    storage (initial 10k next 100k maxextents unlimited pctincrease 0)7  /Table created.www.htz.pw > create index i_access1 on2    access$(d_obj#, order#)3    storage (initial 10k next 100k maxextents unlimited pctincrease 0)4 www.htz.pw > /Index created.www.htz.pw > startup force;ORACLE instance started.Total System Global Area  237998080 bytesFixed Size                  2227216 bytesVariable Size             197133296 bytesDatabase Buffers           33554432 bytesRedo Buffers                5083136 bytesDatabase mounted.Database opened.

------------------作者介绍-----------------------
姓名:黄廷忠
现就职:Oracle中国高级服务团队
曾就职:OceanBase、云和恩墨、东方龙马等
电话、微信、QQ:18081072613
个人博客: (http://www.htz.pw)
CSDN地址: (https://blog.csdn.net/wwwhtzpw)
博客园地址: (https://www.cnblogs.com/www-htz-pw)

http://www.wxhsa.cn/company.asp?id=2021

相关文章:

  • 从需求出发:教你判断选斑斑还是织信
  • PLC结构化文本设计模式——建造者模式(Builder Pattern)
  • C++ - STL - 迭代器
  • MATLAB的智能扫地机器人工作过程仿真
  • linux redis 8.2.1软件开机启动redis.service与etc下的rc.local配置2种方式
  • 在GA中添加Tag-GetDynamicSpecSourceTags().AddTag(NewTag)
  • python如何在函数中使用全局变量?
  • 296、贾生
  • ubuntu 24.04部署mysql8.0.41(glibc2.17)
  • C++ - STL - 键值对pair
  • 第四天学习:LSTM
  • MATLAB的稀疏自编码器实现
  • 题解:P2157 [SDOI2009] 学校食堂
  • LLM 应用开发中的常见模式
  • vue3 与 element-plus
  • 可爱的二维数据结构们
  • 网络安全相关职业
  • 202005_CTFHUB_Redis流量
  • langchain学习之路
  • 通义灵码产品演示: 数据库设计与数据分析
  • win10安装mysql,MySQL5.7详细教程
  • 第二周作业
  • ubuntu 24编译安装libssl.so.1.0.0
  • 9月8-13日小记 - L
  • Task2:利用 Basnet 将Task1中的所有图片转化为显著性图片
  • 代码随想录算法训练营第一天| 704.二分查找、27.移除元素、977.有序数组的平方
  • 让天下没有难查的故障:2025 阿里云 AI 原生编程挑战赛正式启动
  • kuka机器人程序备份
  • AI 测试工具20款
  • VMware安装NOI linux系统教程