当前位置:  数据库>oracle

PL/SQL中三种游标循环效率对比

    来源: 互联网  发布时间:2017-05-24

    本文导语: 这里主要对比以下三种格式的游标循环: 1.单条处理 open 游标; LOOP  FETCH 游标 INTO 变量; EXIT WHEN  条件; END LOOP; CLOSE 游标; 2.批量处理 open 游标; FETCH 游标 BULK COLLECT INTO 集合变量; CLOSE 游标; 3.隐式游标 for x in (sql语句) loop ...--逻辑处...

这里主要对比以下三种格式的游标循环:

1.单条处理

open 游标;

LOOP 

FETCH 游标 INTO 变量;

EXIT WHEN  条件;

END LOOP;

CLOSE 游标;

2.批量处理

open 游标;

FETCH 游标 BULK COLLECT INTO 集合变量;

CLOSE 游标;

3.隐式游标

for x in (sql语句) loop

...--逻辑处理

end loop; 

以上为工作中常见的几种游标处理方式,一般来说批量处理的速度要最好,隐式游标的次之,单条处理的最差,但是在我的实际工作中发现大部分使用的还是第一种游标处理。

归其原因竟是对集合变量及批量处理的效率等问题不了解所致。

推荐阅读:

PL/SQL下连接远程Oracle数据库

PL/SQL“ ORA-14551: 无法在查询中执行 DML 操作”解决

这里简单的测试一下以上三种游标的效率,并分析trace文件来查看这3种处理方式的本质。 

--创建测试大表

00:09:54 SCOTT@orcl> create table big_data as select 'Cc'||mod(level,8) a,'Dd'||
mod(level,13) b from dual connect by level select count(*) from big_data;

  COUNT(*)
----------
    999999

1 row selected.

Elapsed: 00:00:00.07

--分别执行以上三种方式的游标处理的plsql块

00:11:21 SCOTT@orcl> declare
00:17:54  2    cursor c_a is
00:17:54  3      select a from big_data;
00:17:54  4
00:17:54  5    v_a big_data.a%type;
00:17:54  6  begin
00:17:54  7    open c_a;
00:17:54  8    loop
00:17:54  9      fetch c_a into v_a;
00:17:54  10      exit when c_a%notfound;
00:17:54  11    end loop;
00:17:54  12    close c_a;
00:17:54  13  end;
00:17:56  14  /

PL/SQL procedure successfully completed.

Elapsed: 00:00:07.42
00:18:05 SCOTT@orcl> declare
00:19:56  2    cursor c_a is
00:19:56  3      select a from big_data;
00:19:56  4
00:19:56  5  type t_a is table of c_a%rowtype;
00:19:56  6    v_a t_a;
00:19:56  7  begin
00:19:56  8    open c_a;
00:19:56  9    --批量处理
00:19:56  10      fetch c_a bulk collect into v_a;
00:19:56  11    close c_a;
00:19:56  12  end;
00:19:57  13  /

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.64
00:22:55 SCOTT@orcl> declare
00:23:18  2    v_a big_data.a%type;
00:23:18  3    begin
00:23:18  4    --批量处理
00:23:18  5    for x in (select a from big_data) loop
00:23:18  6      v_a:=x.a;
00:23:18  7    end loop;
00:23:18  8  end;
00:23:18  9  /

PL/SQL procedure successfully completed.

Elapsed: 00:00:00.79

注:请保证plsql_optimize_level的参数为2,如果不为2,可能测试结果会不一样.
注意对比消耗时间,1为7.42s, 2为0.64s, 3为0.79s

请继续阅读:


    
 
 

您可能感兴趣的文章:

  • sql 游标的使用—游标FOR循环小例子
  • MS SQL Server游标(CURSOR)的学习使用
  • sql游标的用法简单笔记
  • 教你怎么使用sql游标实例分享
  • sql 取代游标的写法示例
  • sql 游标使用笔记
  • T-SQL常用游标函数实例学习
  • SQL Server 游标语句使用示例
  • SQL Server 游标语句 声明/打开/循环实例
  • SQLServer用t-sql命令批量删除数据库中指定表(游标循环删除)
  • sql server中嵌套游标的例子
  • 在Oracle PL/SQL中游标声明中表名动态变化的方法
  • Sql Server遍历表记录的二种方法(表变量与游标)
  • SQL Server遍历表中记录的2种方法(使用表变量和游标)
  • 用jdbc对access数据库进行操作时出现异常:java.sql.SQLException: [Microsoft][ODBC 驱动程序 管理器] 非法的游标状态
  • SQL Server通用分页存储过程(非游标方式)
  • SQL server使用自定义函数以及游标
  • SQL Server游标的使用/关闭/释放/优化小结
  • SQL Server的通用分页存储过程 未使用游标,速度更快!
  • 学习 SQL Server 2005游标
  • 循环里面执行sql插入语句只执行第一个插入,为什么??
  • sql server for循环的问题
  • shell:sql问题,如何shell循环将不同表数据写入文件中...
  • sql中循环处理当前行数据和上一行数据相加减
  • 请帮我看看这小段代码,为什么不能在循环中执行sql?
  • sql循环语句简单示例与解释
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • mssql server 2012(SQL2012)各版本功能对比
  • SQL中Charindex和Oracle中对应的函数Instr对比
  • SQL批量插入数据几种方案的性能详细对比
  • java命名空间java.sql接口statement的类成员方法: executeupdate定义及介绍
  • 请问,这是什么错误!java.sql.SQLException: [Microsoft][ODBC SQL Server Driver][Named Pipes]??????? SQL Server?虽然分少,但一定给,只要您是前5名回复者中最好的以为!
  • java命名空间java.sql接口connection的类成员方法: nativesql定义及介绍
  • SQL查询分析工具 SQL Workbench/J
  • java命名空间java.sql接口preparedstatement的类成员方法: executeupdate定义及介绍
  • 操作系统 iis7站长之家
  • java命名空间java.sql接口rowid的类成员方法: getbytes定义及介绍
  • SQL Server统计SQL语句执行时间的脚本
  • java命名空间java.sql接口ref的类成员方法: getbasetypename定义及介绍
  • SQL客户端软件 PKLite SQL Client
  • java命名空间java.sql接口databasemetadata的类成员方法: getsqlkeywords定义及介绍
  • SQL语句实现SQL Server 2000及Sql Server 2005日志收缩(批量)
  • java命名空间java.sql接口rowid的类成员方法: tostring定义及介绍
  • SQL客户端管理工具 SQuirreL SQL Client
  • java命名空间javax.sql.rowset接口joinrowset的类成员方法: getwhereclause定义及介绍
  • 如何处理此错误:java.sql.SQLException: [Microsoft][ODBC SQL Server Driver]没有执行可选特性
  • java命名空间java.sql接口statement的类成员方法: execute定义及介绍
  • sql2005 大数据量检索分页的sql代码
  • java命名空间java.sql接口resultset的类成员方法: getcursorname定义及介绍
  • 如何实现连接一次数据库,提交多个sql语句。(sql的批处理)
  • java命名空间java.sql接口resultsetmetadata的类成员方法: getcolumntype定义及介绍
  • 微软网站下载的Ms SQL Server2000 JDBC Driver,必须用英文版的SQL server2000吗?


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,