通过oracle一个特性,加快客户端SELECT LOOP数据的速度。
使用的特性是oracle bulk collect into 技术。
实现方法如下:
1) 在数据库中配置:
一次性返回2000条记录
create or replace procedure pro_test(v_1 out i_table, v_2 out v_table) as
begin
select id, name BULK COLLECT INTO v_1, v_2 from a where rownum <2000 />end;
2 ) 通过JAVA编码,在客户端使用oracle.sql.array
一次性取到所有数据,这比在客户端select 后,再loop速度快多了。
oracle.sql.ARRAY a_test = new oracle.sql.ARRAY(a, oraCon, s1);
oracle.sql.ARRAY b_test = new oracle.sql.ARRAY(b, oraCon, s2);
long aaaa = System.currentTimeMillis();
PreparedStatement pstmt = null;
pstmt = oraCon.prepareCall("{ call pro_test(?,?) }");
pstmt.setObject(1, a_test);
pstmt.setObject(2, b_test);
pstmt.executeUpdate();
测试结果:10000条记录:
开始时间: 1307497501265
aaa0
结束时间:1307497501421
而通过正常的PL/SQL,则需要4.5秒。
可见,速度提升还是很明显的
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/197458/viewspace-1050890/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/197458/viewspace-1050890/