这两天在处理一个数据库性能问题时候,使用了批量绑定和索引表配合,代替了游标和循环,大大提高了过程的执行效率。先整理关于批量绑定的一些基本知识。
1。基本概念:批量绑定时oracle9i新增的一特性,指在单次之心sql操作中传递所有集合元素的数据,在select以及dml操作,批量进行数据处理,大大提高数据处理速度。
2。FORALL语句:
应用程序中执行批量DML操作的时候可以使用FORALL语句。在oracle9i中,使用forall必须有连续的元素,从10g开始,使用indices of和values of,可以有不连续的元素。另外FORALL语句并不是循环语句。三者基本语法如下:
FORALL index in lowbound..upbound(index是隐含定义的整形变量,作为集合元素的下标使用);
FORALL index in indices of collection(indices of 语句用于只取对应collection集合下元素的index值);
FORALL Index in values of index_collection(values of 用于指定index从集合变量index_collection取得);
sql%bulk_rowcount为FORALL提供批量绑定时第i个元素执行的行数。
3。Bulk Collect语句
该语句用于获取批量数据,常用在select into,fetch into和dml语句的返回子句中。
dml返回语句例子:
delete from emp where deptno=:deptno returning ename bulk into ename_table(索引表);
来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/24903632/viewspace-678034/,如需转载,请注明出处,否则将追究法律责任。
转载于:http://blog.itpub.net/24903632/viewspace-678034/