日期:2014-05-16  浏览次数:20382 次

oracle中insert,copy,insert append执行对比
oracle中insert,copy,insert append执行对比

还是由于迁移数据库,测试了insert,copy,insert append的执行速度。

环境:oracle9i向oracle11g迁移,linux系统。

表已建立,只允许插入数据,而不能使用create .. select 或 copy .. create。

1. 建立dblink,供insert,insert append使用。
2. 登录11g数据库。并set timing on
3. 建立视图查看redo size

create redo_size as
select value   www.2cto.com 
from v$mystat, v$statname
where v$mystat.statistic# = v$statname.statistic#
and v$statname.name = 'redo size';

4. insert into dblink_test_tab select * from tran_rec_03@dblink_test;

insert /*+ APPEND */ into dblink_test_tab select * from tran_rec_03@dblink_test;

copy from ispay/ispay@crmtest insert dblink_test_tab using select * from tran_rec_03;

在执行以上所有语句前与后执行select * from redo_size;

5. 得到的结果如下:

redo_size 用时
insert 177821968 4'25"
insert append 3590412 3'15"
copy 124438620 4'20"
数据量:495665
  www.2cto.com 
结论:
insert 需要的时间最多,redo量最大。

insert append 需要的时间最短,redo量最小。

copy则不需要dblink。