文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

2011-11-16 %ROWTYPE的声明与使用

2024-04-02 19:55

关注

http://www.itpub.net/thread-1499223-15-1.html

150楼

我连接到HR用户并运行了如下语句:

CREATE TABLE plch_parts
(
   partnum    NUMBER
, partname   VARCHAR2 (50)
)
/
BEGIN
   INSERT INTO plch_parts
        VALUES (1, 'Chassis');
   COMMIT;
END;
/
CREATE OR REPLACE PACKAGE plch_pkg
IS
   TYPE parts_t IS TABLE OF plch_parts%ROWTYPE
                      INDEX BY PLS_INTEGER;
   PROCEDURE plch_show_parts (parts_in IN parts_t);
END;
/
CREATE OR REPLACE PACKAGE BODY plch_pkg
IS
   PROCEDURE plch_show_parts (parts_in IN parts_t)
   IS
   BEGIN
      FOR indx IN 1 .. parts_in.COUNT
      LOOP
         DBMS_OUTPUT.put_line (parts_in (indx).partname);
      END LOOP;
   END;
END;
/
GRANT SELECT ON plch_parts TO scott
/
GRANT EXECUTE ON plch_pkg TO scott
/

然后我又用SCOTT用户连接并创建了这张表:

CREATE TABLE plch_parts
(
   partnum    NUMBER
, partname   VARCHAR2 (50)
)
/
BEGIN
   INSERT INTO plch_parts
        VALUES (100, 'Wheel');
   COMMIT;
END;
/

下列的哪些选项包含了下列语句块的一个声明部分,从而使得这个块执行之后"Wheel"会被显示出来?

BEGIN
   SELECT *
     BULK COLLECT INTO l_parts
     FROM plch_parts;
   hr.plch_pkg.plch_show_parts (l_parts);
END;

(A)

DECLARE
   TYPE parts_t IS TABLE OF plch_parts%ROWTYPE
                      INDEX BY PLS_INTEGER;
   l_parts   parts_t;
SQL> DECLARE
  2    TYPE parts_t IS TABLE OF plch_parts%ROWTYPE INDEX BY PLS_INTEGER;
  3  
  4    l_parts parts_t;
  5  
  6  BEGIN
  7    SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  8  
  9    yoga.plch_pkg.plch_show_parts(l_parts);
 10  END;
 11  /
DECLARE
  TYPE parts_t IS TABLE OF plch_parts%ROWTYPE INDEX BY PLS_INTEGER;
  l_parts parts_t;
BEGIN
  SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  yoga.plch_pkg.plch_show_parts(l_parts);
END;
ORA-06550: 第 9 行, 第 3 列: 
PLS-00306: 调用 'PLCH_SHOW_PARTS' 时参数个数或类型错误
ORA-06550: 第 9 行, 第 3 列: 
PL/SQL: Statement ignored
SQL>

(B)

DECLARE
   TYPE parts_t IS TABLE OF hr.plch_parts%ROWTYPE
                      INDEX BY PLS_INTEGER;
   l_parts   parts_t;
SQL> DECLARE
  2    TYPE parts_t IS TABLE OF yoga.plch_parts%ROWTYPE INDEX BY PLS_INTEGER;
  3  
  4    l_parts parts_t;
  5  
  6  BEGIN
  7    SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  8  
  9    yoga.plch_pkg.plch_show_parts(l_parts);
 10  END;
 11  /
DECLARE
  TYPE parts_t IS TABLE OF yoga.plch_parts%ROWTYPE INDEX BY PLS_INTEGER;
  l_parts parts_t;
BEGIN
  SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  yoga.plch_pkg.plch_show_parts(l_parts);
END;
ORA-06550: 第 9 行, 第 3 列: 
PLS-00306: 调用 'PLCH_SHOW_PARTS' 时参数个数或类型错误
ORA-06550: 第 9 行, 第 3 列: 
PL/SQL: Statement ignored
SQL>

(C)

DECLARE
   l_parts   hr.plch_pkg.parts_t;
SQL> DECLARE
  2    l_parts yoga.plch_pkg.parts_t;
  3  
  4  BEGIN
  5    SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  6  
  7    yoga.plch_pkg.plch_show_parts(l_parts);
  8  END;
  9  /
Wheel
PL/SQL procedure successfully completed
SQL>

(D)

DECLARE
   SUBTYPE parts_t IS hr.plch_pkg.parts_t;
   l_parts   parts_t;
SQL> DECLARE
  2    SUBTYPE parts_t IS yoga.plch_pkg.parts_t;
  3    l_parts parts_t;
  4  
  5  BEGIN
  6    SELECT * BULK COLLECT INTO l_parts FROM plch_parts;
  7  
  8    yoga.plch_pkg.plch_show_parts(l_parts);
  9  END;
 10  /
Wheel
PL/SQL procedure successfully completed
SQL>

实测用yoga代替hr,test代替scott

答案在158楼

2011-11-16 答案CD.

%ROWTYPE是一种记录,如果你定义两个结构一模一样的记录类型,它们仍然不能够互换,会报类型不匹配的错误。

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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