Oracle(ORA-00214)-undo表空间文件损坏

现象描述

数据库所在机器异常断电导致启动失败,系统显示如下错误信息:

bash 复制代码
ORA-00214: control file '/opt/oracle/db/oradata/iptvmdn/lv_control2tbs' version
117553 inconsistent with file '/opt/oracle/db/oradata/iptvmdn/lv_control1tbs'

可能原因

异常断电导使undo表空间文件损坏,数据库启动失败。
处理步骤

  1. 以oracle用户登录数据库所在机器。
  2. 以sysdba用户连接数据库。
bash 复制代码
% sqlplus / as sysdba
  1. 通过spfile文件创建一个临时的pfile文件。
bash 复制代码
SQL> create pfile='$ORACLE_HOME/dbs/temp_pfile_ora' from spfile;
  1. 退出sqlplus
bash 复制代码
SQL> quit
  1. 在该pfile文件最后添加*.undo_management='MANUAL'。
bash 复制代码
% vi $ORACLE_HOME/dbs/temp_pfile_ora

在此文件最后添加*.undo_management='MANUAL'。

注:在MANUAL模式无法切换undo表空间。

  1. 以sysdba用户连接数据库。
bash 复制代码
% sqlplus / as sysdba
  1. 使用临时pfile文件启动数据库。
bash 复制代码
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;

如果还是无法启动数据库,可以将表空间文件offline。

数据库启动成功,显示如下信息。

bash 复制代码
ORACLE instance started.

Total System Global Area 4142166016 bytes
Fixed Size                  2166208 bytes
Variable Size            2214593088 bytes
Database Buffers         1912602624 bytes
Redo Buffers               12804096 bytes
Database mounted.
Database opened.
  1. 查看并记录回滚段信息。
bash 复制代码
SQL> select SEGMENT_NAME from dba_rollback_segs;
  1. 关闭数据库。
bash 复制代码
SQL> shutdown immediate;
  1. 修改临时pfile文件。
    a.删除"*.undo_management='MANUAL'"。
    b. 添加如下内容。
bash 复制代码
_corrupted_rollback_segments=(_SYSSMU1_1192403689$,_SYSSMU2_1192403689$,_SYSSMU3_1192403689$,_SYSSMU4_1192403689$,_SYSSMU5_1192403689$,_SYSSMU6_1192403689$,_SYSSMU7_1192403689$,_SYSSMU8_1192403689$,_SYSSMU9_1192403689$,_SYSSMU10_1192403689$)

括号中的内容为8中的查询结果。

  1. 使用临时pfile文件启动数据库。
bash 复制代码
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;

启动成功,系统显示如下信息:

bash 复制代码
ORACLE instance started.

Total System Global Area 4142166016 bytes
Fixed Size                  2166208 bytes
Variable Size            2214593088 bytes
Database Buffers         1912602624 bytes
Redo Buffers               12804096 bytes
Database mounted.
Database opened.
  1. 重建undo表空间。
bash 复制代码
SQL> CREATE UNDO TABLESPACE undotbs02 DATAFILE '/var/tmp/cssd_mdn/myundo.dbf' SIZE 2G;

SQL> alter system set undo_tablespace = undotbs2;

SQL> drop tablespace UNDOTBS1 including contents cascade constraints;

SQL> CREATE UNDO TABLESPACE undotbs01 DATAFILE '/dev/oramdn_dg/lv_undotbs' size 9G;

SQL> autoextentd off;

SQL> alter system set undo_tablespace = UNDOTBS1;
  1. 关闭数据库。
bash 复制代码
SQL> shutdown immediate;
  1. 重启数据库。
bash 复制代码
SQL> startup

启动成功,系统显示如下信息:

bash 复制代码
OORACLE instance started.

Total System Global Area 4142166016 bytes
Fixed Size                  2166208 bytes
Variable Size            2214593088 bytes
Database Buffers         1912602624 bytes
Redo Buffers               12804096 bytes
Database mounted.
Database opened.

建议与总结

Oralce数据库尽量不要强行断电。控制文件、参数文件一定要做好备份。

相关推荐
小光学长1 分钟前
基于vue框架的防疫科普网站0838x(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
极限实验室7 分钟前
使用 Docker Compose 简化 INFINI Console 与 Easysearch 环境搭建
数据库·docker·devops
飞翔的佩奇11 分钟前
Java项目:基于SSM框架实现的旅游协会管理系统【ssm+B/S架构+源码+数据库+毕业论文】
java·数据库·mysql·毕业设计·ssm·旅游·jsp
智海观潮1 小时前
Flink CDC支持Oracle RAC架构CDB+PDB模式的实时数据同步吗,可以上生产环境吗
大数据·oracle·flink·flink cdc·数据同步
float_六七3 小时前
SQL六大核心类别全解析
数据库·sql·oracle
Code季风4 小时前
将 gRPC 服务注册到 Consul:从配置到服务发现的完整实践(上)
数据库·微服务·go·json·服务发现·consul
Boilermaker19924 小时前
【Java EE】SpringIoC
前端·数据库·spring
霸王龙的小胳膊5 小时前
泛微虚拟视图-数据虚拟化集成
数据库
灵犀学长5 小时前
解锁Spring Boot多项目共享Redis:优雅Key命名结构指南
数据库·redis
轩情吖5 小时前
Qt的信号与槽(二)
数据库·c++·qt·信号·connect·信号槽·