oracle 数据块 修复,Oracle中修复数据块的损坏

本文介绍了在Oracle 11g环境下,如何创建表空间并管理,随后演示了数据文件损坏后的修复过程,包括使用DBV检查、避开损坏块的方法、系统设置事件以及利用exp/imp进行数据恢复。但注意,这可能导致数据丢失。方法适用于数据库管理员,出自php中文网。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、先创建一个用于实验的表空间 create tablespace block datafile size 1M extent management local; ndash;因为是11g

1、先创建一个用于实验的表空间

create tablespace block datafile size 1M extent management local; –因为是11g所以使用了AMS

alter user ff default tablespace block;

alter user ff quota unlimited on block;

2、损坏数据文件

关闭database后用编辑器随便修改几个字符,然后启动database

当访问相关被损坏的block时,将会遇到错误

3、对此使用dbv检查数据文件

dbv file=block.dbf blocksize=8192

假设获得第35块被损坏了

4、恢复步骤

①select tablespace_name, segment_type, owner, segment_name from dba_extents where file_id=4 and 35 between block_id and block_id+blocks-1;

如果确定损失的是数据,就ok

设置内部事件,,设置在全表扫描时跳过损坏的数据块

alter system set events=’10231 trace name context forever,level 10′;

随后,可以用exp和imp进行导入导出,进行恢复。但这毕竟导致相依blocks中数据的丢失。

logo.gif 本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:php中文网

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值