Discuz!NT
欢迎 游客 , 注册 | 登录 | 会员 | 界面 | 简洁版本 | 在线 | 帮助
商都网教育宝典宝库

发表新主题 回复该主题
本主题被查看463次, 共1个帖子, 1页, 当前为第1页     选择页数: 1      跳转到第   上一主题   下一主题
标题: 一次大批量数据备份和导入工作
-[尕硴]
超级版主
UID: 71
来自:
精华: 130
积分: 14003
帖子: 12909
注册: 2007-10-22 17:59:00
状态: 离线
威望: 444.00
金钱: 3355.00 元
只看楼主 2008-03-11 14:36
一次大批量数据备份和导入工作
有一个数据表的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;
#1  
发表新主题 回复该主题
本主题被查看463次, 共1个帖子, 1页, 当前为第1页     选择页数: 1      跳转到第







现在的时间是 2008-10-16 09:23:59

版权所有 商都网教育宝典
         Powered by Discuz!NT 1.0.6666    Copyright © 2001-2008 Comsenz Inc.
Processed in 0.03 seconds