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创建序列的语法
分享文章:Oracle游标表达式和表函数
标题URL:http://www.mswzjz.cn/qtweb/news0/239800.html
攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能