Oracle 报错ORA-15173:entry ‘temp4.dbf‘ does not exist in directory ‘tempfile

oracle Datadg 日志报错tempfile文件
“ORA-15173:entry ‘temp4.dbf’ does not exist in directory ‘tempfile’“

ORA-01122: database file 10245 failed verification check
ORA-01110: data file 10245: '+DATADG/mesdb78/tempfile/temp4.dbf'
ORA-01565: error in identifying file '+DATADG/mesdb78/tempfile/temp4.dbf'
ORA-17503: ksfdopn:2 Failed to open file +DATADG/mesdb78/tempfile/temp4.dbf
ORA-15173: entry 'temp4.dbf' does not exist in directory 'tempfile'

这是由于在primary端创建temp.dbf文件时,datadg端未创建temp文件造成的。但是在datadg 段Oracle中却会有这个路径,可是你的系统中并没有temp*.dbf这个文件,这就造成了如上报错,在tempfile directory下找不到temp4.dbf。
到这儿有的朋友可能就在想我去tempfile directory下创建一个temp*.dbf不就行了吗?那就错了,在操作系统下创建的文件是不会被oracle识别的,只有通过Oracle 创建的才会被识别。

在创建过程中会出现一个粗心大意的错误,就是直接在oracle上”alter tablespace TEMPDATA add tempfile ‘+DATADG/mesdb78/tempfile/temp4.dbf’ size **;“。然后就会报错已存在该temp4.dbf。这时就会疑惑了,怎么已经报没有temp文件的错了,这会儿还会报有这个文件的错呢?
这是因为Oracle 的v$tempfile已经有该文件了,此时只需将Oracle中的temp drop掉,再重新 alter tablespace创建temp文件就OK了。

下面我们手动创建dg的temp:
----注意,dg创建temp文件时需要与主库的temp文件size保持一致。----

1.先在主库rac中查看主库的temp.dbf size:

select * from v$tempfile order by name;

2.再在dg中dorp掉temp.dbf:

alter tablespace TEMPDATA drop tempfile '+DATADG/mesdb78/tempfile/temp4.dbf';

3.创建新的temp:

alter tablespace TEMPDATA add tempfile '+DATADG/mesdb78/tempfile/temp4.dbf' size ***;

若有多个temp文件,依上面的步骤依次执行一遍即可。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值