文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle中游标,数组的使用

2024-04-02 19:55

关注

1) select * from cnbs_security_role_menu for update;


2)oracle 中游标的使用: http://www.cnblogs.com/sc-xx/archive/2011/12/03/2275084.html

declare 

       --类型定义

      cursor c_job is

       select combine_no,plan_code,flag from rate_combine  where plan_code='C01' and rownum <10;

       --定义一个游标变量

       c_row c_job%rowtype;

begin

       open c_job;

         loop

           --提取一行数据到c_row

           fetch c_job into c_row;

           --判读是否提取到值,没取到值就退出

           --取到值c_job%notfound 是false 

           --取不到值c_job%notfound 是true

           exit when c_job%notfound;

           dbms_output.put_line(c_row.combine_no||'-'||c_row.plan_code||'-'||c_row.flag);

         end loop;

       --关闭游标

      close c_job;

end;



3)如果使用固定长度的数组,而且不需要在外部定义可以如下定义

declare 

   type ar is varray(15) of varchar2(12); --声明数组类型

   rt ar:=ar('dd','ff','ss'); --声明数组类型变量rt,并赋初值

   i integer:=1; 

begin

     

     for i in 1..rt.count loop

       -- rt(i):=i;

        dbms_output.put_line('count='||rt(i));

     end loop;

     

end;


4 )如果我们要使用的数组长度不能预计,我们可以按如下方法作:

declare

     TYPE numtab IS TABLE OF varchar2(50) INDEX BY BINARY_INTEGER; //定义一个数组类型;

     arr numtab; //使用这个类型声明一个变量;

     i integer:=1;  

begin     

     for i in 1..100 loop

       arr(i):=i;//为变量赋值

       dbms_output.put_line('arr['||i||']='||arr(i));

     end loop;

     

     dbms_output.put_line('count='||arr.count);

end ;


5)--- 使用带参数的游标;

declare

     CURSOR stock_cur(symbol_in VARCHAR2) IS 

       SELECT * FROM rate_combine_nr nr WHERE nr.combine_no=symbol_in;

       

     stock_info stock_cur%ROWTYPE;   

begin

  

   OPEN stock_cur('G600000001'); --打开游标;

   loop   

     FETCH stock_cur INTO stock_info; --从游标中取值

     exit when stock_cur%notfound;

       dbms_output.put_line(stock_info.combine_no||'-'||stock_info.department_code);   

   end loop;

  close stock_cur; --关闭游标

end;


阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯