一. 数据文件校验
dbv file=block.dbf blocksize=8192
二.回滚段名称查询
strings system01.dbf | grep _SYSSMU | cut -d $ -f 1 | sort -u #oracle10g
strings system01.dbf | grep _SYSSMU | cut -d $ -f 1 | sort -u #oracle9i
三. 数据库mount状态可用视图.
v$controlfile
v$log
v$datafile
v$logfile
v$recover_file;
v$recovery_log;
v$transaction
v$tempfile
v$tablespace
四。系统Oracle UNDO表空间的重建
SQL>CREATE UNDO TABLESPACE "UNDOTEMP" DATAFILE '/oradata1/dbnms/undotemp.dbf' SIZE 20M;
SQL>ALTER SYSTEM SET UNDO_TABLESPACE = UNDOTEMP;
SQL>drop tablespace undotbs1 including contents and datafiles;
五。ORACLE 9I TEMP 表空间的重建
SQL> create temporary tablespace TEMP1 tempfile '/oradata1/dbnms/temp1.dbf' size 100M ;
SQL> alter database default temporary tablespace temp1;
SQL> drop tablespace temp including contents and datafiles;
六。非当前redolog损坏
alter database clear unarchived logfile group 3 ;
七。当前redolog损坏
SQL>_allow_resetlogs_corruption=TRUE
SQL> recover database until cancel;
cancel
SQL>alter database open resetlogs;
重建库后建议执行:ANALYZE TABLE ...VALIDATE STRUCTURE CASCADE;
八。临时文件损坏
1、脱机该数据文件:
SQL>alter database datafile '文件名全名' offline drop;
2、打开数据库
SQL>alter database open
3、删除该临时表空间
SQL>drop tablespace temp(或其它临时表空间名称);
4、重新创建该表空间,并重新分配给用户。
九。回滚文件损坏数据库关闭
*._corrupted_rollback_segments ='_SYSSMU1$','_SYSSMU10$','_SYSSMU2$','_SYSSMU3$','_SYSSMU4$','_SYSSMU5$','_SYSSMU9$'
*.undo_management='AUTO'
*.undo_tablespace='UNDOTEMP' #不能用system