ORA-00942: table or view does not exist实例无法启动问题

一线提出数据库实例(Oracle 19c)无法启动,也不存在dest状态的共享内存,查看alert日志,报错如下:

发现在open阶段校验失败,系统表缺失,backup validate datafile 1,3系统数据文件也没有数据坏块。

1、开10046 trace确认哪张表缺失

mount数据库

oradebug setmypid

oradebug tracefile_name

oradebug event 10046 trace name context forever,level 12;

alter database open;

查看trace文件,发现access$表缺失

2、在同版本的数据库中查到access表的定义以及其索引
sql 复制代码
set lines 400 pages 9999 long 9999;
select dbms_metadata.get_ddl('TABLE','ACCESS$','SYS') from dual;

SELECT OWNER,INDEX_NAME FROM DBA_INDEXES WHERE TABLE_NAME='ACCESS$';

select dbms_metadata.get_ddl('INDEX','I_ACCESS1','SYS') from dual;
3、尝试将数据库启动并创建access$表

startup upgrade --可能较慢,需要等会

upgrade模式启动数据库只允许sysdba用户登录,允许数据字典表缺失

sql 复制代码
CREATE TABLE "SYS"."ACCESS$" 
   (    "D_OBJ#" NUMBER NOT NULL ENABLE,
        "ORDER#" NUMBER NOT NULL ENABLE,
        "COLUMNS" RAW(126),
        "TYPES" NUMBER NOT NULL ENABLE
   ) PCTFREE 10 PCTUSED 40 INITRANS 1 MAXTRANS 255
  TABLESPACE "SYSTEM";
  
CREATE INDEX "SYS"."I_ACCESS1" ON "SYS"."ACCESS$" ("D_OBJ#", "ORDER#")  TABLESPACE "SYSTEM";
4、normal模式重启数据库

由于startup upgrade的限制,需要normal模式重启数据库

shutdown immediate

startup

此时不再报错,及时将数据库备份恢复到其他正常库

5、复盘

access$表是一个系统表,存储library cache中的对象,此基表可被sysdba删除,此次故障应该是误删基表导致

相关推荐
可涵不会debug4 小时前
【IoTDB】时序数据库选型指南:工业大数据场景下的技术突围
数据库·时序数据库
ByteBlossom4 小时前
MySQL 面试场景题之如何处理 BLOB 和CLOB 数据类型?
数据库·mysql·面试
麦兜*4 小时前
MongoDB Atlas 云数据库实战:从零搭建全球多节点集群
java·数据库·spring boot·mongodb·spring·spring cloud
Slaughter信仰4 小时前
深入理解Java虚拟机:JVM高级特性与最佳实践(第3版)第十章知识点问答(10题)
java·jvm·数据库
麦兜*4 小时前
MongoDB 在物联网(IoT)中的应用:海量时序数据处理方案
java·数据库·spring boot·物联网·mongodb·spring
努力也学不会java4 小时前
【设计模式】抽象工厂模式
java·设计模式·oracle·抽象工厂模式
-Xie-5 小时前
Mysql杂志(十六)——缓存池
数据库·mysql·缓存
七夜zippoe5 小时前
缓存与数据库一致性实战手册:从故障修复到架构演进
数据库·缓存·架构
一个天蝎座 白勺 程序猿5 小时前
Apache IoTDB(5):深度解析时序数据库 IoTDB 在 AINode 模式单机和集群的部署与实践
数据库·apache·时序数据库·iotdb·ainode