一次大批量数据备份和导入工作

本文介绍了一种针对Oracle中接近6亿条记录的大表进行优化的方法,通过导出、删除原表并重新导入的方式,实现数据更新及空间回收,并详细描述了操作步骤。

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

有一个数据表的insert、delete操作频繁,空间无释放。唯有进行一次导出、DROP、导入操作。

当前数据量:接近6亿

估计其中有一部分数据太旧,所以使用带条件的导出。

$>export NLS_LANG=AMERICAN_AMERICA.ZHS16GBK
$>exp user/pass file=XXX.dmp buffer=409600000 tables=mybigtable query=/" where somedate/>=XXX/"

导出数据约3.7亿,占用空间约57G。

导出后drop掉原表

drop table mybigtable cascade constraints

 导入

imp user/pass file=XXX

导入本来是很简单的操作,但需要很大的临时表空间(最后占用了12G)

需要有大的空间存放temp01.dbf文件

temp01.dbf文件的清空及转移

(Oracle9i 或以上)

先确保没有其他人或其他任务在进行数据库操作

由于原来的temp文件已经占用了很大的空间,而且该磁盘内没有足够空间存入该文件。所以在清空原来的文件的基础上,把该文件设定在另一磁盘内。

alter database tempfile '/opt/oracle/oradata/orcl/temp01.dbf' drop including datafiles;

alter tablespace temp add tempfile '/newplace/temp01.dbf' size 512M autoextend on next 250M maxsize unlimited;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值