|
    
- UID
- 61170
- 帖子
- 8123
- 精华
- 1
- 积分
- 16582
- 人气值
- 12496 点
- 努力值
- 21243 点
- 推广注册人数
- 3 个人
- 阅读权限
- 200
- 性别
- 男
- 在线时间
- 692 小时
- 注册时间
- 2008-2-29
- 最后登录
- 2008-11-23
 
|
楼主
发表于 2008-8-3 17:51
| 只看该作者
有一个数据表的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; |
|