文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

SYS_REFCURSOR作为过程参数的表现是什么

2024-04-02 19:55

关注

这篇文章主要讲解了“SYS_REFCURSOR作为过程参数的表现是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“SYS_REFCURSOR作为过程参数的表现是什么”吧!

我创建了如下的表并填充数据:

CREATE TABLE plch_tab (item VARCHAR2 (10))
/
 
BEGIN
   INSERT INTO plch_tab
        VALUES ('Keyboard');
   INSERT INTO plch_tab
        VALUES ('Mouse');
   COMMIT;
END;
/

然后我创建了这个函数,从游标变量取得一行数据并返回:

CREATE OR REPLACE FUNCTION plch_getitem (
   plch_cur IN SYS_REFCURSOR)
   RETURN plch_tab.item%TYPE
IS
   lvretval   plch_tab.item%TYPE;
BEGIN
   FETCH plch_cur INTO lvretval;
   RETURN lvretval;
END plch_getitem;
/

现在我需要写一个程序块来获取表里的数据行,并且显示行数和最后一行的项目名称。下面就是这个接近完成的版本:

DECLARE
   lvitem     plch_tab.item%TYPE;
   test_cur   SYS_REFCURSOR;
BEGIN
   OPEN test_cur FOR
        SELECT * FROM plch_tab ORDER BY item;
   
   DBMS_OUTPUT.put_line ('Count = ' || test_cur%ROWCOUNT);
   DBMS_OUTPUT.put_line ('Item = ' || NVL (lvitem, 'NOT SET'));
   CLOSE test_cur;
END;
/

下列的选项中哪些可用来代替 从而使得这个块执行之后,屏幕上可以见到如下输出?

Count = 2

Item = Mouse

 

(A)

FETCH test_cur INTO lvitem;
lvitem := plch_getitem (test_cur);
SQL> DECLARE
  2    lvitem   plch_tab.item%TYPE;
  3    test_cur SYS_REFCURSOR;
  4  BEGIN
  5    OPEN test_cur FOR
  6      SELECT * FROM plch_tab ORDER BY item;
  7  
  8    FETCH test_cur
  9      INTO lvitem;
 10    lvitem := plch_getitem(test_cur);
 11  
 12    DBMS_OUTPUT.put_line('Count = ' || test_cur%ROWCOUNT);
 13    DBMS_OUTPUT.put_line('Item = ' || NVL(lvitem, 'NOT SET'));
 14  
 15    CLOSE test_cur;
 16  END;
 17  /
Count = 2
Item = Mouse
PL/SQL procedure successfully completed
SQL>

(B)

lvitem := plch_getitem (test_cur);
lvitem := plch_getitem (test_cur);
SQL> DECLARE
  2    lvitem   plch_tab.item%TYPE;
  3    test_cur SYS_REFCURSOR;
  4  BEGIN
  5    OPEN test_cur FOR
  6      SELECT * FROM plch_tab ORDER BY item;
  7  
  8    lvitem := plch_getitem(test_cur);
  9    lvitem := plch_getitem(test_cur);
 10  
 11    DBMS_OUTPUT.put_line('Count = ' || test_cur%ROWCOUNT);
 12    DBMS_OUTPUT.put_line('Item = ' || NVL(lvitem, 'NOT SET'));
 13  
 14    CLOSE test_cur;
 15  END;
 16  /
Count = 2
Item = Mouse
PL/SQL procedure successfully completed
SQL>

(C)

lvitem := plch_getitem (test_cur);
FETCH test_cur INTO lvitem;
SQL> DECLARE
  2    lvitem   plch_tab.item%TYPE;
  3    test_cur SYS_REFCURSOR;
  4  BEGIN
  5    OPEN test_cur FOR
  6      SELECT * FROM plch_tab ORDER BY item;
  7  
  8    lvitem := plch_getitem(test_cur);
  9    FETCH test_cur
 10      INTO lvitem;
 11  
 12    DBMS_OUTPUT.put_line('Count = ' || test_cur%ROWCOUNT);
 13    DBMS_OUTPUT.put_line('Item = ' || NVL(lvitem, 'NOT SET'));
 14  
 15    CLOSE test_cur;
 16  END;
 17  /
Count = 2
Item = Mouse
PL/SQL procedure successfully completed
SQL>

(D)

lvitem := plch_getitem (test_cur);
FETCH plch_cur INTO lvitem;
SQL> DECLARE
  2    lvitem   plch_tab.item%TYPE;
  3    test_cur SYS_REFCURSOR;
  4  BEGIN
  5    OPEN test_cur FOR
  6      SELECT * FROM plch_tab ORDER BY item;
  7  
  8    lvitem := plch_getitem(test_cur);
  9    FETCH plch_cur
 10      INTO lvitem;
 11  
 12    DBMS_OUTPUT.put_line('Count = ' || test_cur%ROWCOUNT);
 13    DBMS_OUTPUT.put_line('Item = ' || NVL(lvitem, 'NOT SET'));
 14  
 15    CLOSE test_cur;
 16  END;
 17  /
DECLARE
  lvitem   plch_tab.item%TYPE;
  test_cur SYS_REFCURSOR;
BEGIN
  OPEN test_cur FOR
    SELECT * FROM plch_tab ORDER BY item;
  lvitem := plch_getitem(test_cur);
  FETCH plch_cur
    INTO lvitem;
  DBMS_OUTPUT.put_line('Count = ' || test_cur%ROWCOUNT);
  DBMS_OUTPUT.put_line('Item = ' || NVL(lvitem, 'NOT SET'));
  CLOSE test_cur;
END;
ORA-06550: 第 9 行, 第 9 列: 
PLS-00201: 必须声明标识符 'PLCH_CUR'
ORA-06550: 第 9 行, 第 3 列: 
PL/SQL: SQL Statement ignored
SQL>
答案ABC. 答案D错误因为plch_cur这个名称在函数之外是不可见的。
REF CURSOR作为IN参数(不需要定义为IN OUT),在FETCH之后游标仍然会前移,所以你调用之后再FETCH会取到下一行。

感谢各位的阅读,以上就是“SYS_REFCURSOR作为过程参数的表现是什么”的内容了,经过本文的学习后,相信大家对SYS_REFCURSOR作为过程参数的表现是什么这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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