Oracle游标表达式和表函数

数据库 Oracle
Oracle游标表达式是SQL语言的一个元素,它也可以作为PL/SQL过程或函数的实参来使用,这与表函数结合具有非常大的意义。

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 触发器来完成画面。) 
 

 

 

【编辑推荐】

Oracle存储过程的使用实例

Oracle命令行自定义编辑器vi

oracle命令行登录的实现

Oracle查询表空间使用情况

Oracle创建序列的语法

责任编辑:段燃 来源: 互联网
相关推荐

2023-11-02 18:45:00

Rust编程表达式

2011-05-30 16:11:46

Javascript

2017-08-01 00:19:15

Javascript函数函数声明

2009-08-31 17:11:37

Lambda表达式

2018-09-27 15:25:08

正则表达式前端

2014-01-05 17:41:09

PostgreSQL表达式

2021-06-28 08:01:57

JS 函数表达式函数声明

2010-04-28 18:17:16

Oracle CASE

2012-04-28 15:22:46

PHP

2020-10-16 06:40:25

C++匿名函数

2021-08-31 07:19:41

Lambda表达式C#

2010-09-10 15:20:11

SQL函数计算表达式

2009-07-21 14:38:08

Scalamatch表达式break和conti

2009-09-17 09:09:50

Lambda表达式Linq查询

2022-05-26 08:53:47

Go函数代码

2021-08-07 07:21:26

AndroidKotlinLambda

2010-11-16 15:40:21

oracle游标

2009-09-16 09:58:53

PHP正则表达式函数

2009-09-16 10:43:22

PHP正则表达式函数

2009-10-12 10:11:08

Lambda表达式编写
点赞
收藏

51CTO技术栈公众号