本文主要是介绍Oracle(ORA-00214)-undo表空间文件损坏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
现象描述
数据库所在机器异常断电导致启动失败,系统显示如下错误信息:
ORA-00214: control file '/opt/oracle/db/oradata/iptvmdn/lv_control2tbs' version
117553 inconsistent with file '/opt/oracle/db/oradata/iptvmdn/lv_control1tbs'
可能原因
异常断电导使undo表空间文件损坏,数据库启动失败。
处理步骤
- 以oracle用户登录数据库所在机器。
- 以sysdba用户连接数据库。
% sqlplus / as sysdba
- 通过spfile文件创建一个临时的pfile文件。
SQL> create pfile=’$ORACLE_HOME/dbs/temp_pfile_ora’ from spfile;
- 退出sqlplus
SQL> quit
- 在该pfile文件最后添加*.undo_management=‘MANUAL’。
% vi $ORACLE_HOME/dbs/temp_pfile_ora
在此文件最后添加*.undo_management=‘MANUAL’。
注:在MANUAL模式无法切换undo表空间。
- 以sysdba用户连接数据库。
% sqlplus / as sysdba
- 使用临时pfile文件启动数据库。
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;
如果还是无法启动数据库,可以将表空间文件offline。
数据库启动成功,显示如下信息。
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.
- 查看并记录回滚段信息。
SQL> select SEGMENT_NAME from dba_rollback_segs;
- 关闭数据库。
SQL> shutdown immediate;
- 修改临时pfile文件。
a.删除“*.undo_management=‘MANUAL’”。
b. 添加如下内容。
_corrupted_rollback_segments=(_SYSSMU1_1192403689$,_SYSSMU2_1192403689$,_SYSSMU3_1192403689$,_SYSSMU4_1192403689$,_SYSSMU5_1192403689$,_SYSSMU6_1192403689$,_SYSSMU7_1192403689$,_SYSSMU8_1192403689$,_SYSSMU9_1192403689$,_SYSSMU10_1192403689$)
括号中的内容为8中的查询结果。
- 使用临时pfile文件启动数据库。
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;
启动成功,系统显示如下信息:
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.
- 重建undo表空间。
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;
- 关闭数据库。
SQL> shutdown immediate;
- 重启数据库。
SQL> startup
启动成功,系统显示如下信息:
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数据库尽量不要强行断电。控制文件、参数文件一定要做好备份。
这篇关于Oracle(ORA-00214)-undo表空间文件损坏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!