oracle表 游标,Oracle游标表达式和表函数

Oracle游标表达式是Oracle数据库中的重要概念,下面就为您详细介绍Oracle游标表达式和表函数方面的知识,供您参考学习之用。

Oracle游标表达式(有时称为游标子队列)是 SQL 语言的一个元素,在 Oracle9i 之前,SQL 和某些程序设计环境(但不包括 PL/SQL)支持游标表达式。Oracle9i 引入了 PL/SQL 对游标表达式的支持。例如,可以在打开 PL/SQL 游标的 SELECT 语句中使用游标表达式,并在之后进行适当的控制。它也可以作为 PL/SQL 过程或函数的实参来使用,这与表函数结合具有非常大的意义。

Oracle9i 之前的版本也支持表函数(以初步的形式),而在 Oracle9i 中作了许多重大改进。现在可以编写表函数来将行一经计算就以流水线方式立即发送,极大地改善了 first rows 示例中的响应时间。表函数的编写现在可以做到接收 SELECT 语句作为输入,允许将任意数量的变换以菊花链形式串接起来,避免了存储中间结果的需要。而且也可以编写表函数,使它的计算并行进行,从而利用 Oracle 的并行查询机制。

能够并行执行表函数意味着现在无需序列化,就可能在数据仓库应用程序的提取、转换和加载 (aka ETL) 阶段利用 PL/SQL 的功能。

游标变量 — 概括

Oracle9i 从由本地动态 SQL 值的游标变量批量获取的增强功能

在 PL/SQL 中使用游标表达式

使用游标表达式作为 PL/SQL 函数的实参

"YOUNG MANAGERS" 示例

表函数 — 概括

流水线表函数 — Oracle9i 新增

从一个表函数输送数据到下一个表函数 — Oracle9i新增

再次访问 "Young Managers" 示例 — 表函数方法

Fanout:利用边界效应使用表函数

表函数并行执行 — Oracle9i新增

基于模式级别类型的表函数语法

当编写表函数返回模式级别类型时,调用它所需的语法稍微有些冗长。为完整起见,在示例代码中对其进行示范。

表函数和游标表达式的商务利益

游标表达式允许在兼容查询中为重用进行逻辑封装,这改善了开发人员的生产率和应用可靠性。

表函数实现了功能的改善,允许在 SELECT 子句的 FROM 列表中调用来自任意外部数据源的字节组集合和由任意计算合成的字节组集合。为方便起见,它们可以用来定义 VIEW,从而产生了新的功能。

表函数可以将行作为 VIEW 发送 — 这些行来自任意的源于 Oracle 表(因此包括别的表函数)的复杂 PL/SQL 变换 — 并且无需存储计算后的行。这提高了速度和可伸缩性。并改善了开发人员的生产率和应用可靠性。

表函数的输入参数使 VIEW 可参数化,更进一步发挥了 VIEW 的作用,这提高了代码重用性从而改善了开发人员的生产率和应用可靠性。

一个具有参考游标输入参数的表函数可以作为数据源和另一个表函数一起被调用。因而表函数可以以菊花链形式串接起来,从而允许模块化程序设计并因此使程序设计更容易,并且改善了重用性和应用程序强健性。

表函数可以并行执行,提高了速度和可伸缩性。结合菊花链特性,使得表函数尤其适合于执行提取、转换和加载操作的数据仓库应用程序。

Fanout(来自表函数中自主事务的 DML)对数据仓库应用程序添加了特别值得关注的功能。

表函数允许对存储在内嵌表中的数据如同关联存储一样来查询,也允许关联存储的数据如作为内嵌表存储的数据一样来查询。 (在多层集合代码示例中给出的赛跑运动员训练记录示例中对此进行示范。)这允许数据持续存储格式与访问数据的应用程序的设计之间保持真正的独立。(表函数上可以定义 VIEW,在 VIEW 上可以创建 INSTEAD OF 触发器来完成画面。)

【编辑推荐】

【责任编辑:段燃 TEL:(010)68476606】

点赞 0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值