一线提出数据库实例(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删除,此次故障应该是误删基表导致