批量绑定

        这两天在处理一个数据库性能问题时候,使用了批量绑定和索引表配合,代替了游标和循环,大大提高了过程的执行效率。先整理关于批量绑定的一些基本知识。

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/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值