暂无图片
暂无图片
暂无图片
暂无图片
暂无图片

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

michaelliu 2025-05-07
130

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

ORA-00214: control file '/opt/oracle/db/oradata/iptvmdn/lv_control2tbs' version
117553 inconsistent with file '/opt/oracle/db/oradata/iptvmdn/lv_control1tbs'
1
2
可能原因
异常断电导使undo表空间文件损坏,数据库启动失败。
处理步骤

以oracle用户登录数据库所在机器。
以sysdba用户连接数据库。
% sqlplus / as sysdba
1
通过spfile文件创建一个临时的pfile文件。
SQL> create pfile=’$ORACLE_HOME/dbs/temp_pfile_ora’ from spfile;
1
退出sqlplus
SQL> quit
1
在该pfile文件最后添加*.undo_management=‘MANUAL’。
% vi $ORACLE_HOME/dbs/temp_pfile_ora
1
在此文件最后添加*.undo_management=‘MANUAL’。
注:在MANUAL模式无法切换undo表空间。

以sysdba用户连接数据库。
% sqlplus / as sysdba
1
使用临时pfile文件启动数据库。
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;
1
如果还是无法启动数据库,可以将表空间文件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;
1
关闭数据库。
SQL> shutdown immediate;
1
修改临时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$)
1
括号中的内容为8中的查询结果。

使用临时pfile文件启动数据库。
SQL> startup pfile=$ORACLE_HOME/dbs/temp_pfile_ora;
1
启动成功,系统显示如下信息:

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;
1
重启数据库。
SQL> startup
1
启动成功,系统显示如下信息:

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.

AI写代码
建议与总结
Oralce数据库尽量不要强行断电。控制文件、参数文件一定要做好备份。
————————————————

DoubleJing

原文链接:https://blog.csdn.net/qq_41944882/article/details/141660943

「喜欢这篇文章,您的关注和赞赏是给作者最好的鼓励」
关注作者
【版权声明】本文为墨天轮用户原创内容,转载时必须标注文章的来源(墨天轮),文章链接,文章作者等基本信息,否则作者和墨天轮有权追究责任。如果您发现墨天轮中有涉嫌抄袭或者侵权的内容,欢迎发送邮件至:contact@modb.pro进行举报,并提供相关证据,一经查实,墨天轮将立刻删除相关内容。

评论