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
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
结论:
insert 需要的时间最多,redo量最大。
insert append 需要的时间最短,redo量最小。
copy则不需要dblink。