通过管道导入生成的文件:
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