oracle imp性能优化,优化Oracle IMP

通过管道导入生成的文件:

1.通过 mknod -p 建立管道 $ mknod /home/exppipe p

2.导入生成的压缩文件$ imp test/test file=/home/exppipe fromuser=test touser=macro

&gunzip < exp.dmp.gz > /home/exppipe

3.删除管道$ rm –fr /home/exppipe

备份操作可以运用管道,如下:

mknod exp_pipe p /* 生成命名管道 */

exp system/manager@testdb file=./exp_pipe full=y /* 将备份数据送往管道 */

compress exp_pipe > expfull.dmp.Z /* 生成压缩备份文件*/

恢复操作也可以利用管道,跳过将文件解压缩,生成原始文件的过程,如下:

mknod imp_pipe p /* 生成相应的命名管道 */

uncompress -c expfull.dmp.Z > imp_pipe/* 将解压缩数据送入管道 */

imp system/manager@testdb file=./imp_pipe fromuser=scott touser=scott /* 将管道数据导入数据库testdb*/

1.3 优化

1. 加快exp速度

加大large_pool_size,可以提高exp的速度

采用直接路径的方式(direct=y),数据不需要经过内存进行整合和检查.

设置较大的buffer,如果导出大对象,小buffer会失败。

export文件不在ORACLE使用的驱动器上

不要export到NFS文件系统

UNIX环境:用管道模式直接导入导出来提高imp/exp的性能

2. 加快imp速度

建立一个indexfile,在数据import完成后在建立索引

将import文件放在不同的驱动器上

增加DB_BLOCK_BUFFERS

增加LOG_BUFFER

用非归档方式运行ORACLE:ALTER DATABASE NOARCHIVELOG;

建立大的表空间和大的回滚段,OFFLINE其他回滚段,回滚段的大小为最大表的1/2

使用 COMMIT=N

使用ANALYZE=N

单用户模式导入

UNIX环境:用管道模式直接导入导出来提高imp/exp的性能

3. 通过unix/Linux PIPE管道加快exp/imp速度

通过管道导出数据:

1.通过mknod -p建立管道

$ mknod /home/exppipe p --在目录/home下建立一个管道exppipe 注意参数p

2.通过exp和gzip导出数据到建立的管道并压缩

$ exp test/test file=/home/exppipe & gzip < /home/exppipe > exp.dmp.gz

$ exp test/test tables=bitmap file=/home/newsys/test.pipe & gzip < /home/newsys/test.pipe > bitmap.dmp.gz

3.导出成功完成之后删除建立的管道

$ rm -rf /home/exppipe

通过管道导入生成的文件:

1.通过mknod -p建立管道

$ mknod /home/exppipe p

2.导入生成的压缩文件

$ imp test/test file=/home/exppipe fromuser=test touser=macro & gunzip < exp.dmp.gz > /home/exppipe

3.删除管道

$ rm –fr /home/exppipe

4. 全库导入的一般步骤

1.先全库加rows=n把结构导进去

$ imp system/manager file=exp.dmp log=imp.log full=y rows=n indexes=n

2.使业务用户的触发器失效/删除主键和唯一索引

spool drop_pk_u.sql

select 'alter table '||table_name||' drop constraint '||constraint_name||';'

from user_constraints

where

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值