文章详情

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

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么使用数据库新功能PL/SCOPE

2024-04-02 19:55

关注

本篇内容主要讲解“怎么使用数据库新功能PL/SCOPE”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么使用数据库新功能PL/SCOPE”吧!

我在会话中打开PL/Scope:

ALTER SESSION SET plscope_settings='identifiers:all'
/

然后我创建了如下的表和包:

CREATE TABLE plch_stuff
(
   amount   NUMBER
, rating   INTEGER
)
/
CREATE OR REPLACE PACKAGE plch_pkg
IS
   PROCEDURE do_stuff;
END plch_pkg;
/
CREATE OR REPLACE PACKAGE BODY plch_pkg
.......
END plch_pkg;
/

噢,抱歉,我不能让你看到包体的代码!请继续....

我对PL/Scope的USER_IDENTIFIERS视图进行如下查询:

SELECT type, usage
  FROM user_identifiers
WHERE object_name = 'PLCH_PKG'
ORDER BY 1, 2
/

我看到这些结果:

TYPE               USAGE
------------------ -----------
FUNCTION           CALL      
ITERATOR           DECLARATION
ITERATOR           REFERENCE  
LABEL              DECLARATION
PACKAGE            DECLARATION
PACKAGE            DEFINITION
PROCEDURE          DECLARATION
PROCEDURE          DEFINITION
VARIABLE           DECLARATION
VARIABLE           REFERENCE  
VARIABLE           REFERENCE

下面关于plch_pkg包的哪些句子是正确的?

(A)

包体里面没有任何私有(PRIVATE)的子程序。

(B)

do_stuff过程里面可能包含一个FORALL语句。

(C)

包体里面必须包含一个PACKAGE级别的变量(即不是在do_stuff里面声明的)。

(D)

do_stuff过程必须包含一个GOTO语句。
2011-11-9答案AB.
(A)
包体里面没有任何私有(PRIVATE)的子程序。
对应每个包里定义的过程你会看到两条记录:
PROCEDURE          DECLARATION
PROCEDURE          DEFINITION
对应每个包里定义的函数你会看到两条记录:
FUNCTION           DECLARATION
FUNCTION           DEFINITION
结果里面只有这样一对:
PROCEDURE          DECLARATION
PROCEDURE          DEFINITION
它就是对应于do_stuff过程,不再有其他子程序了。
(B)
do_stuff过程里面可能包含一个FORALL语句。
一个FORALL语句就像一个FOR循环,定义并且使用隐性游标。输出里这两行:
ITERATOR           DECLARATION
ITERATOR           REFERENCE  
有可能对应FORALL语句。
(C)
包体里面必须包含一个PACKAGE级别的变量(即不是在do_stuff里面声明的)。
这仅仅是“可能”而非“必须”。我们知道包体里面某处定义了一个变量,根据是这两行输出:
VARIABLE           DECLARATION
VARIABLE           REFERENCE
但这个变量可能在do_stuff内部定义。为了确定这个变量是不是PACKAGE级的,你必须知道所有程序单元的最小行号,然后看看这个变量定义行号是否在此之前。
(D)
do_stuff过程必须包含一个GOTO语句。
输出里面有这一行:
LABEL              DECLARATION
因此我们知道有一个标号被声明了,它可能出现在程序某处,像这样:
<<label_name>>
但是输出里面并没有指示这个标号被引用, 否则的话我们应该看到另外一行输出:
LABEL              REFERENCE
(newkid加注:即使看到标号被引用,也不意味着GOTO, 比如退出循环的EXIT也可以引用标号)

到此,相信大家对“怎么使用数据库新功能PL/SCOPE”有了更深的了解,不妨来实际操作一番吧!这里是亿速云网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

阅读原文内容投诉

免责声明:

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

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

软考中级精品资料免费领

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

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

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

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

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

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

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