oracle插入性能优化,Oracle-insert性能优化
看見朋友導入數(shù)據(jù),花了很長時間都沒完成!其實有很多快速的方法,整理下! 向表中插入數(shù)據(jù)有很多辦法,但是方法不同,性能差別很
看見朋友導入數(shù)據(jù),,花了很長時間都沒完成!其實有很多快速的方法,整理下!
向表中插入數(shù)據(jù)有很多辦法,但是方法不同,性能差別很大.
----1.原始語句
drop table t1 purge;
create table t1
(
sid number,
sname varchar2(20)
) tablespace test;
create or replace procedure proc01
(
sname varchar2
)
as
begin
for i in 1..10000000
loop
execute immediate
'insert into t1(sid,sname) values('||i||','''||sname||''')';
commit;
end loop;
end;
/
alter system flush shared_pool;
set timing on;
exec proc01('ocpyangtest');
已用時間: 02: 02: 54.12
----2.綁定變量
drop table t1 purge;
create table t1
(
sid number,
sname varchar2(20)
) tablespace test;
create or replace procedure proc02
(
sname varchar2
)
as
begin
for i in 1..10000000
loop
execute immediate
'insert into t1(sid,sname) values(:no'||','''||sname||''')' using i;
commit;
end loop;
end;
/
alter system flush shared_pool;
set timing on;
exec proc02('ocpyangtest');
已用時間: 00: 22: 59.79
select count(*) from t1;
----3.靜態(tài)語句
drop table t1 purge;
create table t1
(
sid number,
sname varchar2(20)
) tablespace test;
create or replace procedure proc03
as
begin
for i in 1..10000000
loop
insert into t1 values(i,'ocpyangtest');
commit;
end loop;
end;
/
alter system flush shared_pool;
set timing on;
exec proc03;
已用時間: 00: 20: 42.42
select count(*) from t1;
----4.批量提交
drop table t1 purge;
create table t1
(
sid number,
sname varchar2(20)
) tablespace test;
create or replace procedure proc04
as
begin
for i in 1..10000000
loop
insert into t1 values(i,'ocpyangtest');
end loop;
commit;
end;
/
alter system flush shared_pool;
set timing on;
exec proc04;
已用時間: 00: 11: 48.42
----5.集合
drop table t2 purge;
create table t2
(
sid number,
sname varchar2(20)
) tablespace test;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
insert into t2 select sid,sname from t1;
已用時間: 00: 01: 02.18
commit;
select count(*) from t2;
----6. 集合+append
drop table t2 purge;
create table t2
(
sid number,
sname varchar2(20)
) tablespace test;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
insert /* + append */ into t2 select sid,sname from t1;
已用時間: 00: 00: 36.94
commit;
select count(*) from t2;
----7. 集合+append+nologging
drop table t2 purge;
create table t2
(
sid number,
sname varchar2(20)
) nologging tablespace test;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
insert /* + append */ into t2 select sid ,sname from t1;
已用時間: 00: 00: 35.07
commit;
select count(*) from t2;
----8.數(shù)據(jù)加載1
drop table t2 purge;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
create table t2
as
select sid,sname from t1;
已用時間: 00: 00: 25.91
select count(*) from t2;
----9.數(shù)據(jù)加載2
drop table t2 purge;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
create table t2 nologging
as
select sid,sname from t1;
已用時間: 00: 00: 04.89
select count(*) from t2;
----10.數(shù)據(jù)加載+并行
drop table t2 purge;
alter system flush shared_pool;
select count(*) from t1;
set timing on;
create table t2 nologging parallel 24 --根據(jù)自己服務器情況
as
select sid,sname from t1;
已用時間: 00: 00: 02.89
select count(*) from t2;
本條技術(shù)文章來源于互聯(lián)網(wǎng),如果無意侵犯您的權(quán)益請點擊此處反饋版權(quán)投訴 本文系統(tǒng)來源:php中文網(wǎng)
總結(jié)
以上是生活随笔為你收集整理的oracle插入性能优化,Oracle-insert性能优化的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: vue项目中 axios请求拦截器与取消
- 下一篇: 标准正态分布表_表达矩阵的归一化和标准化