本系列链接导航:

[独孤九剑]Oracle知识点梳理(一)表空间、用户

[独孤九剑]Oracle知识点梳理(二)数据库的连接

[独孤九剑]Oracle知识点梳理(三)导入、导出

[独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL

[独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View

[独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence

[独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor

[独孤九剑]Oracle知识点梳理(八)常见Exception

[独孤九剑]Oracle知识点梳理(九)数据库常用对象之package

[独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数

5.6、cursor操作

  游标的使用场景大致有:

    a) 显示游标:function或procedure中,用于获取某些值进行遍历操作

    b) 动态游标:procedure中,用于返回查询结果

5.6.1、显示游标:在代码段、function、procdeure中创建cursor,用于取值

  • 隐式游标
 declare
cursor myCursor is
select name from person;
  vNames varchar2(128);
begin
  --遍历游标
  for c in myCursor loop --隐式打开、关闭游标
    vNames:=vNames||','||c; -- 可以包含复杂逻辑
  end loop;
end;
  • 显示游标
 declare
  cursor myCursor is --定义游标
    select * from person;
  my_c myCursor%rowtype --定义游标变量
begin
  open myCursor;
  loop
    fetch myCursor into my_c;
    exit when c%notfound;
    /*code here*/ --编写复杂逻辑
  end loop;   Exception
    when others then
      close myCursor;   if myCursor%isopen then
    close myCursor;
end;

  上面写的两个列子比较简单,下面是网上摘抄显示游标例子,很详细:

  对于显式游标的运用分为四个步骤:

  • 定义游标---Cursor [Cursor Name] IS;
  • 打开游标---Open [Cursor Name];
  • 操作数据---Fetch [Cursor name]
  • 关闭游标---Close [Cursor Name],这个Step绝对不可以遗漏。

  以下是三种常见显式Cursor用法。
1)Set serveroutput on;

 declare
  ---define Cursor
  Cursor cur_policy is
    select cm.policy_code, cm.applicant_id, cm.period_prem,cm.bank_code,cm.bank_account
        from t_contract_master cm
        where cm.liability_state = 2
            and cm.policy_type = 1
            and cm.policy_cate in ('','','')
            and rownum < 5
        order by cm.policy_code desc;
  curPolicyInfo cur_policy%rowtype;---定义游标变量
Begin
  open cur_policy; ---open cursor
  Loop
    --deal with extraction data from DB
    Fetch cur_policy into curPolicyInfo;
    Exit when cur_policy%notfound;     Dbms_Output.put_line(curPolicyInfo.policy_code);
  end loop;
  Exception
    when others then
      close cur_policy;
    Dbms_Output.put_line(Sqlerrm);   if cur_policy%isopen then
    --close cursor
    close cur_policy;
  end if;
end; /

2) Set serveroutput on; 

 declare
  Cursor cur_policy is
    select cm.policy_code, cm.applicant_id, cm.period_prem,cm.bank_code,cm.bank_account
      from t_contract_master cm
      where cm.liability_state = 2
        and cm.policy_type = 1
        and cm.policy_cate in ('','','')
        and rownum < 5
      order by cm.policy_code desc;
  v_policyCode t_contract_master.policy_code%type;
  v_applicantId t_contract_master.applicant_id%type;
  v_periodPrem t_contract_master.period_prem%type;
  v_bankCode t_contract_master.bank_code%type;
  v_bankAccount t_contract_master.bank_account%type;
Begin
  open cur_policy;
  Loop
    Fetch cur_policy into v_policyCode,
                v_applicantId,
                v_periodPrem,
                v_bankCode,
                v_bankAccount;
    Exit when cur_policy%notfound;     Dbms_Output.put_line(v_policyCode);
  end loop;
  Exception
28    when others then
      close cur_policy;
    Dbms_Output.put_line(Sqlerrm);   if cur_policy%isopen then
    close cur_policy;
  end if;
end;
/

3)Set serveroutput on; 

 declare
  Cursor cur_policy is
    select cm.policy_code, cm.applicant_id, cm.period_prem,cm.bank_code,cm.bank_account
        from t_contract_master cm
        where cm.liability_state = 2
          and cm.policy_type = 1
          and cm.policy_cate in ('','','')
          and rownum < 5
        order by cm.policy_code desc;
Begin
  For rec_Policy in cur_policy loop
    Dbms_Output.put_line(rec_policy.policy_code);
  end loop;
  Exception
    when others then
    Dbms_Output.put_line(Sqlerrm); end; /

5.6.2、动态游标:在procdeure中使用cursor,用于返回查询结果

  与隐式Cursor,显式Cursor的区别:

  • Ref Cursor是可以通过在运行期间传递参数来获取数据结果集。
  • 而另外两种Cursor(隐式游标和显示游标),是静态的,在编译期间就决定数据结果集。

5.6.2.1、定义动态游标

 Declare
  ---define cursor type name
  type cur_type is ref cursor;
  cur_policy cur_type;
  sqlStr varchar2(500);
  rec_policy t_contract_master%rowtype;
begin
  ---define 动态Sql
  sqlStr := 'select cm.policy_code, cm.applicant_id, cm.period_prem,cm.bank_code,
              cm.bank_account from t_contract_master cm
          where cm.liability_state = 2
              and cm.policy_type = 1
              and cm.policy_cate in (2,3,4)
              and rownum < 5
            order by cm.policy_code desc ';
  ---Open Cursor
  open cur_policy for sqlStr;
  loop
    fetch cur_policy into rec_policy.policy_code, rec_policy.applicant_id, rec_policy.period_prem,
                  rec_policy.bank_code,rec_policy.bank_account;
    exit when cur_policy%notfound;     Dbms_Output.put_line('Policy_code:'||rec_policy.policy_code);   end loop;
close cur_policy; end;
/

另外,在定义package时,可以在包头中定义动态游标类型,在包体中使用,如在procedure中用于定义返回参数类型。详见package的操作。

[独孤九剑]Oracle知识点梳理(七)数据库常用对象之Cursor的更多相关文章

  1. [独孤九剑]Oracle知识点梳理(九)数据库常用对象之package

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  2. [独孤九剑]Oracle知识点梳理(六)数据库常用对象之Procedure、function、Sequence

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  3. [独孤九剑]Oracle知识点梳理(五)数据库常用对象之Table、View

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  4. [独孤九剑]Oracle知识点梳理(十)%type与%rowtype及常用函数

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  5. [独孤九剑]Oracle知识点梳理(二)数据库的连接

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  6. [独孤九剑]Oracle知识点梳理(八)常见Exception

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  7. [独孤九剑]Oracle知识点梳理(四)SQL语句之DML和DDL

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  8. [独孤九剑]Oracle知识点梳理(三)导入、导出

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

  9. [独孤九剑]Oracle知识点梳理(一)表空间、用户

    本系列链接导航: [独孤九剑]Oracle知识点梳理(一)表空间.用户 [独孤九剑]Oracle知识点梳理(二)数据库的连接 [独孤九剑]Oracle知识点梳理(三)导入.导出 [独孤九剑]Oracl ...

随机推荐

  1. 42和为S的两个数字

    题目描述 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 输出描述: 对应每个测试案例,输出两个数,小的先输出. 设置 ...

  2. 【HackerRank】QuickSort(稳定快排,空间复杂度O(n))

    QuickSort In the previous challenge, you wrote a partition method to split an array into 2 sub-array ...

  3. 【Head First Servlets and JSP】笔记5:HttpServletResponse resp

    [HttpServletResponse resp] [由servlet处理响应] 1.一般可以用通过resp获得一个输出流(writer),然后通过输出流将HTML写入响应.例如: resp.set ...

  4. 【Flask】Sqlalchemy 子查询

    ### subquery:子查询可以让多个查询变成一个查询,只要查找一次数据库,性能相对来讲更加高效一点.不用写多个sql语句就可以实现一些复杂的查询.那么在sqlalchemy中,要实现一个子查询, ...

  5. scp 和 pscp

    今天在做项目遇到了两个问题,做一些总结. 1.在项目中,防火墙的的相关配置是关于cisco企业级防火墙的配置,并不是window防火墙. 2. 在Linux上,   scp     linux文件   ...

  6. VS中一个强大的功能,将Json或者XML黏贴为类

    有时候需要传递json,或者是json结构复杂,看的杂乱无章,我们可以将这个json复制下来,然后将它写成类的形式,VS中已经帮我们很好的实现了这个功能,我们只需要选择   编辑===>> ...

  7. Qt构造函数的参数:QObject *parent = Q_NULLPTR

    几乎所有的Qt类的构造函数都会有一个parent参数.这个参数通常是QObject* 或者是 QWidget* 类型的.很多情况下它都会有一个初始值0,因此,即便你不去给它复制也没有丝毫的问题.于是, ...

  8. INSPIRED启示录 读书笔记 - 第20章 基本产品

    消减功能还是延长工期 不要再试图定义最终产品,转而定义只满足基本要求的产品,简称基本产品 1.产品经理与设计师合作设计产品的高保真原型,这个原型只具备实现商业目标的最基本功能要求,以及良好的用户体验和 ...

  9. MongoDB快速入门(三)- 集合

    创建集合 MongoDB 的 db.createCollection(name, options) 用于创建集合. 在命令中, name 是要创建集合的名称. Options 是一个文档,用于指定集合 ...

  10. Datax官方笔记总结

    # DataX DataX 是阿里巴巴集团内被广泛使用的离线数据同步工具/平台,实现包括 MySQL.SQL Server.Oracle.PostgreSQL.HDFS.Hive.HBase.OTS. ...