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删除,此次故障应该是误删基表导致

相关推荐
大锦终18 分钟前
【MySQL】内置函数
数据库·mysql
猿小喵20 分钟前
索引优化-MySQL性能优化
数据库·mysql·性能优化
n***F8751 小时前
修改表字段属性,SQL总结
java·数据库·sql
q***78373 小时前
mysql表添加索引
数据库·mysql
翔云1234563 小时前
MySQL 机器重启后,gtid_executed 是如何初始化的
数据库·mysql·adb
JAVA学习通4 小时前
Mysql进阶---存储过程&变量&SQL编程
数据库·mysql
阿里云大数据AI技术4 小时前
朝阳永续基于阿里云 Milvus 构建金融智能投研产品“AI 小二”
数据库·人工智能
百***49004 小时前
Redis-配置文件
数据库·redis·oracle
老纪的技术唠嗑局4 小时前
OceanBase 年度发布会 Hands-on AI Workshop 回顾
数据库