Skip to main content

ORA-01122: database file 22 failed verification check

Today when I tried to restart my test database I got strange but known error.

SQL> startup  
 ORA-32004: obsolete and/or deprecated parameter(s) specified  
 ORACLE instance started.  
 Total System Global Area 5344731136 bytes  
 Fixed Size         2163168 bytes  
 Variable Size      2298482208 bytes  
 Database Buffers     3036676096 bytes  
 Redo Buffers        7409664 bytes  
 Database mounted.  
 ORA-01122: database file 22 failed verification check  
 ORA-01110: data file 22: '/u01/app/oracle/oradata/???/archive_tbs01.dbf'  
 ORA-01200: actual file size of 65536 is smaller than correct size of 402176 


After researching it means inconsistency of controlfile. So, we need recreate or restore it from backup.

Do one of the following:

SQL > alter database backup controlfile to trace;  
 Database altered.

or

 SQL> ALTER DATABASE BACKUP CONTROLFILE TO '/u01/app/oracle/admin/PROD/bdump/controlfile.bkp';  
 Database altered. 

or

SQL> ALTER DATABASE BACKUP CONTROLFILE TO TRACE AS '/u01/app/oracle/admin/PROD/bdump/controlfile.trc';  
 Database altered. 

shutdown database and start it on nomount state:

SQL> shut immediate  
 ORA-01109: database not open  
 Database dismounted.  
 ORACLE instance shut down.

 SQL> startup nomount  
 ORA-32004: obsolete and/or deprecated parameter(s) specified  
 ORACLE instance started.  
 Total System Global Area 5344731136 bytes  
 Fixed Size         2163168 bytes  
 Variable Size      2298482208 bytes  
 Database Buffers     3036676096 bytes  
 Redo Buffers        7409664 bytes  
 SQL>


edit your trace file and try to create  --I created createnewcontrolfile.sql file


 SQL > @createnewcontrolfile.sql  
 CREATE CONTROLFILE REUSE DATABASE "???" RESETLOGS ARCHIVELOG  
   MAXLOGFILES 16  
   MAXLOGMEMBERS 3  
   MAXDATAFILES 100  
   MAXINSTANCES 8  
   MAXLOGHISTORY 2921  
 LOGFILE  
  GROUP 1 '/u01/app/oracle/oradata/???/redo1.log' SIZE 400M,  
  GROUP 2 '/u01/app/oracle/oradata/???/redo2.log' SIZE 400M,  
  GROUP 3 '/u01/app/oracle/oradata/???/redo3.log' SIZE 400M,  
  GROUP 4 '/u01/app/oracle/oradata/???/redo4.log' SIZE 400M,  
  GROUP 5 '/u01/app/oracle/oradata/???/redo5.log' SIZE 400M,  
  GROUP 6 '/u01/app/oracle/oradata/???/redo6.log' SIZE 400M  
 -- STANDBY LOGFILE  
 DATAFILE  
  '/u01/app/oracle/oradata/???/system01.dbf',  
 ...  
  '/u01/app/oracle/oradata/???/FCJ_DATA_TS_13.dbf'  
 CHARACTER SET AL32UTF8; 


At the end recover database using new controlfile

 SQL> recover database using backup controlfile

Now open the database and enjoy

 SQL> alter database open; 

Comments

Popular posts from this blog

Fix ORA-01139: RESETLOGS option only valid after an incomplete database recovery

While shutting down my TEST database process was hanged. Then I had to use shutdown abort. But when I wanted to start database it did not open. SQL> select name from v$database; NAME --------- TEST SQL> shut abort; ORACLE instance shut down. SQL> startup mount ORACLE instance started. Total System Global Area 6597406720 bytes Fixed Size 2265664 bytes Variable Size 3204451776 bytes Database Buffers 3372220416 bytes Redo Buffers 18468864 bytes Database mounted. SQL> alter database open; alter database open * ERROR at line 1: ORA-03113: end-of-file on communication channel Process ID: 6552 Session ID: 191 Serial number: 3  What`s wrong?  SQL> alter database open resetlogs; ERROR:    ORA-03114: not connected to ORACLE    SQL> exit Disconnected from Oracle Database 11g Enterprise Edition Release 11.2.0.4.0 - 64bit Pr...

Fix: ORA-13639: The current operation was interrupted because it timed out.

Sometimes SQL Tuning Advisor interrupts cause time limit took more than defined. You have to analyze it or increase value. Here you can see increasing of value. Example result of sql select                  execution_name, advisor_name,                  to_char(execution_start,'dd-mon-yy hh:mi:ss') execution_start,                  to_char(execution_end,'dd-mon-yy hh:mi:ss') execution_end, status,error_message from dba_advisor_executions where task_name = 'SYS_AUTO_SQL_TUNING_TASK' order by execution_start; Check value of TIME_LIMIT`s parameter : SQL> column parameter_value for A35 SQL> select parameter_name, parameter_value from dba_advisor_parameters where task_name = 'SYS_AUTO_SQL_TUNING_TASK' and parameter_name in ('TIME_LIMIT', 'DEFAULT_EXECUTION_TYP...

How to fix ORA-26040: Data block was loaded using the NOLOGGING option

Today I faced with new ORA error. After solving I want to share this experience with yours. So, today 5`th datafile of my database was corrupted (/u01/app/oracle/oradata/ulfet_db/example01.dbf). After recover via RMAN I saw strange error. RMAN> recover datafile 5 block 443; Starting recover at 24-MAR-13 using channel ORA_DISK_1 channel ORA_DISK_1: restoring block(s) channel ORA_DISK_1: specifying block(s) to restore from backup set restoring blocks of datafile 00005 channel ORA_DISK_1: reading from backup piece /u01/app/oracle/flash_recovery_area/ULFET_DB/backupset/2013_03_24/o1_mf_nnndf_TAG20130324T223233_8nykp220_.bkp channel ORA_DISK_1: piece handle=/u01/app/oracle/flash_recovery_area/ULFET_DB/backupset/2013_03_24/o1_mf_nnndf_TAG20130324T223233_8nykp220_.bkp tag=TAG20130324T223233 channel ORA_DISK_1: restored block(s) from backup piece 1 channel ORA_DISK_1: block restore complete, elapsed time: 00:00:03 starting media recovery media recovery complete, elapsed ti...