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数据库尽量不要强行断电。控制文件、参数文件一定要做好备份。

相关推荐
heartbeat..4 小时前
Spring AOP 全面详解(通俗易懂 + 核心知识点 + 完整案例)
java·数据库·spring·aop
麦聪聊数据6 小时前
MySQL并发与锁:从“防止超卖”到排查“死锁”
数据库·sql·mysql
AC赳赳老秦7 小时前
DeepSeek 私有化部署避坑指南:敏感数据本地化处理与合规性检测详解
大数据·开发语言·数据库·人工智能·自动化·php·deepseek
YMatrix 官方技术社区8 小时前
YMatrix 存储引擎解密:MARS3 存储引擎如何超越传统行存、列存实现“时序+分析“场景性能大幅提升?
开发语言·数据库·时序数据库·数据库架构·智慧工厂·存储引擎·ymatrix
辞砚技术录9 小时前
MySQL面试题——索引2nd
数据库·mysql·面试
linweidong9 小时前
C++thread pool(线程池)设计应关注哪些扩展性问题?
java·数据库·c++
欧亚学术10 小时前
突发!刚刚新增17本期刊被剔除!
数据库·论文·sci·期刊·博士·scopus·发表
oMcLin10 小时前
如何在Oracle Linux 8.4上搭建并优化Kafka集群,确保高吞吐量的实时数据流处理与消息传递?
linux·oracle·kafka
黑白极客10 小时前
怎么给字符串字段加索引?日志系统 一条更新语句是怎么执行的
java·数据库·sql·mysql·引擎
大厂技术总监下海11 小时前
数据湖加速、实时数仓、统一查询层:Apache Doris 如何成为现代数据架构的“高性能中枢”?
大数据·数据库·算法·apache