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

相关推荐
cyt涛几秒前
MyBatis之手动映射
xml·数据库·mybatis·查询·resultmap·手动映射
付宇轩1 小时前
进程的重要函数
linux·数据库
深夜吞食1 小时前
MySQL详解:数据类型、约束
数据库·mysql
Violet永存1 小时前
MySQL:undo log
数据库·mysql
桶将军T1 小时前
SEAFARING靶场渗透
数据库·web安全
Data 3172 小时前
经典sql题(二)求连续登录最多天数用户
大数据·数据库·数据仓库·sql·mysql
服装学院的IT男2 小时前
【Android 13源码分析】WindowContainer窗口层级-3-实例分析
android·数据库
小王是个弟弟3 小时前
HQL-计算不一样的 MUV
数据库·hive·sql
自身就是太阳3 小时前
深入理解 Spring 事务管理及其配置
java·开发语言·数据库·spring
不惑_3 小时前
初识 performance_schema:轻松掌握MySQL性能监控
数据库·mysql