Oracle Insert分批提交「建议收藏」
大家好,又见面了,我是你们的朋友全栈君。
oracle中分批提交insert 事务,以防止redo占用太多可以分批提交事务:以下是三种不同的pl/sql体:
1、编写一个简单的PL/SQL块来模拟逐行提交的情况,注意观察执行时间。
我们的目标是将t_ref表中的数据全部插入到t中。 sec@ora10g> set timing on
sec@ora10g> DECLARE 2 BEGIN 3 FOR cur IN (SELECT * FROM t_ref) LOOP 4 INSERT INTO t VALUES cur; 5 COMMIT; 6 END LOOP; 7 END; 8 /
PL/SQL procedure successfully completed.
Elapsed: 00:03:12.77
逐行提交的情况下,一共用时3分12秒。
2、再来模拟批量提交的情况。 sec@ora10g> truncate table t;
Table truncated.
sec@ora10g> DECLARE 2 v_count NUMBER; 3 BEGIN 4 FOR cur IN (SELECT * FROM t_ref) LOOP 5 INSERT INTO t VALUES cur; 6 v_count := v_count + 1; 7 IF v_count >= 100 THEN 8 COMMIT; 9 END IF; 10 END LOOP; 11 COMMIT; 12 END; 13 /
PL/SQL procedure successfully completed.
Elapsed: 00:01:27.69
此时共用时1分27秒,大约是逐行提交方法一半的时间。由此可见,对于Oracle应该尽量以批量提交的方式来完成工作。
3、最后我们使用Oracle更高级的方法完成上面的任务,体验一下极限速度。 sec@ora10g> DECLARE 2 CURSOR cur IS 3 SELECT * FROM t_ref; 4 TYPE rec IS TABLE OF t_ref%ROWTYPE; 5 recs rec; 6 BEGIN 7 OPEN cur; 8 WHILE (TRUE) LOOP 9 FETCH cur BULK COLLECT 10 INTO recs LIMIT 100; 11 FORALL i IN 1 .. recs.COUNT 12 INSERT INTO t VALUES recs (i); 13 COMMIT; 14 EXIT WHEN cur%NOTFOUND; 15 END LOOP; 16 CLOSE cur; 17 END; 18 /
Elapsed: 00:00:09.75
type book_rec is record(
standing_book_id number
,book_code varchar2(4000)
…
)
type book_no_tb1 is table of book_rec index by pls_integer;
l_book_detail book_no_tb1;
open Asy_init(book_id,…);
loop
FETCH Asy_init buck collect
into l_book_detail limit c_detail_limit;
exit when l_book_detail.count = 0;
forall i in l_book_detail.First .. l_book_detail.Last
insert into…
()values
(
l_book_detail(i).standing_book_id
…
);
end loop;
close asy_init;
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/160982.html原文链接:https://javaforall.cn
相关文章
- oracle r修改表名,oracle中修改表名「建议收藏」
- Oracle 分页「建议收藏」
- Oracle 错误总结及问题解决 ORA「建议收藏」
- Oracle创建表空间「建议收藏」
- Oracle存储过程详细教程「建议收藏」
- Oracle中的NVL函数「建议收藏」
- oracle的nvl函数的使用解析「建议收藏」
- Oracle DBA 路途遥远「建议收藏」
- Oracle创建用户与表空间的绝对干货(建议收藏)
- Oracle的相除运算:实例分析(oracle相除)
- 处理处理Oracle违反约束的建议(oracle违反约束)
- Oracle培训:攻克技术关口(oracle培训资料)
- 一步掌握Oracle与大数据的连接:Oracle大数据连接器(oracle大数据连接器)
- Oracle数据库优化实战 面试题分析(oracle优化面试题)
- Oracle免密登录遭遇惨痛失败(oracle免密登录失败)
- 面向基于 Oracle 的未来FMMM 技术上的机遇与挑战(fmmm oracle)
- Oracle中用于限定年份的技术(oracle中限定年份)
- 妙用Oracle准确去除数据中的小数部分(oracle 中去余取整)
- 上月1号Oracle数据库运行情况追踪报告(oracle 上月1号)
- Oracle VW智能数据库管理解决方案(oracle vw)
- Oracle SE和SA助推企业转型成功(oracle se sa)
- Oracle OWM助力企业IT架构变革(oracle ower)
- 以Oracle促进MyJob的发展(oracle myjob)