微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

oracle 11G undo表空间错误

1.打开数据库提示undo表空间不存在

sql> alter database open;                 
alter database open
*
ERROR at line 1:
ORA-01092: ORACLE instance terminated. disconnection forced
ORA-30012: undo tablespace 'UNDOTBS01' does not exist or of wrong type
Process ID: 3236
Session ID: 1 Serial number: 5

解决方法:

[oracle@oracle ~]$ sqlplus / as sysdba
sql*Plus: Release 11.2.0.1.0 Production on Wed Aug 24 10:22:24 2016
copyright (c) 1982, 2009, Oracle.  All rights reserved.
Connected to an idle instance.
sql> startup mount
ORACLE instance started.

Total System Global Area  776646656 bytes
Fixed Size            2217384 bytes
Variable Size          557845080 bytes
Database Buffers      213909504 bytes
Redo Buffers            2674688 bytes
Database mounted.

sql> select name from v$datafile;

NAME
--------------------------------------------------------------------------------
/home/oracle/app/oradata/orcl/system01.dbf
/home/oracle/app/oradata/orcl/sysaux01.dbf
/home/oracle/app/oradata/orcl/undotbs01.dbf            --undo表空间的数据文件
/home/oracle/app/oradata/orcl/users01.dbf
/home/oracle/app/oradata/orcl/tong.dbf

sql> show parameter undo
NAME                     TYPE     VALUE
------------------------------------ ----------- ------------------------------
undo_management              string     AUTO
undo_retention                 integer     900
undo_tablespace              string     UNDOTBS1      --undo表空间的名字
sql> select name from v$tablespace;

NAME
------------------------------
SYstem
SYSAUX
UNDOTBS1    --undo表空间的名字
USERS
TEMP
TONG1
6 rows selected.
sql>

思路:根据启动oracle的错误可以看出,错误信息的undo表空间的名字与数据库里面的名字不一至,此时要在init.orcl.ora文件修改undo_tablespace的值,用pfile文件启动数据库.

[oracle@oracle ~]$ cd $ORACLE_HOME/dbs
[oracle@oracle dbs]$ vim initorcl.ora
*.undo_tablespace='UNDOTBS1'              --修改这行的值

[oracle@oracle ~]$ sqlplus / as sysdba
sql*Plus: Release 11.2.0.1.0 Production on Wed Aug 24 10:26:06 2016
copyright (c) 1982, 2009, Oracle.  All rights reserved.
Connected to an idle instance.
sql> startup mount pfile='/home/oracle/app/product/11.2.0/dbhome_1/dbs/initorcl.ora'
ORACLE instance started.

Total System Global Area  776646656 bytes
Fixed Size            2217384 bytes
Variable Size          557845080 bytes
Database Buffers      213909504 bytes
Redo Buffers            2674688 bytes
Database mounted.
sql> alter database open;

Database altered.
sql> create spfile='/home/oracle/app/product/11.2.0/dbhome_1/dbs/spfileorcl.ora' from pfile;

File created.                  --pfile文件创建spfile文件
sql> shutdown immediate           --重启数据库
Database closed.
Database dismounted.
ORACLE instance shut down.
sql> startup
ORACLE instance started.

Total System Global Area  776646656 bytes
Fixed Size            2217384 bytes
Variable Size          557845080 bytes
Database Buffers      213909504 bytes
Redo Buffers            2674688 bytes
Database mounted.
Database opened.
sql>

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐