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

oracle表 游标,Oracle游标表达式和表函数相关推荐

  1. oracle存储过程详解--游标 实现增、删、改、查的

    注:以下是转来的内容,但是设计PLSQL代码,原文有问题,所以PLSQL代码我都验证修改了.测试需要在scott/tiger下进行,对于没有的表,需要自行创建,表复制的语句为 CREATE TABLE ...

  2. 13、oracle数据库下的游标

    ORACLE下的游标操作 游标是sql的一个内存工作区,由系统或者用户以变量的形式定义.游标的作用是用于临时存储从数据库中提取的数据块.游标有静态游标.动态游标之分,静态游标又可分为隐式游标和显式游标 ...

  3. Oracle存储过程中使用游标来批量解析CLOB字段里面的xml字符串:

    摘要:之前在项目中使用到了Oracle数据库中通过触发器去调用存储过程执行数据解析并Update到对应的数据表中,但是,经过一段时间的测试使用发现,如果job那天停掉了,然后你再重新新建job的话,这 ...

  4. oracle中创建游标,oracle 存储过程创建游标

    Oracle与Sql Server差异点详解 1.create函数或存储过程异同点 Oracle 创建函数或存储过程一般是 create or replace -- SQL SERVER 则是在创建之 ...

  5. oracle创建多个游标,Oracle——游标的创建和使用

    游标 SQL语言是面向集合的,是对指定列的操作.如果要对列中的指定行进行操作,就必须使用游标. 当在PL/SQL块中执行查询语句(SELECT) 和数据操纵语句(DML) 时,Oracle会为其分配一 ...

  6. oracle 如何创建游标,Oracle--plsql游标创建和使用

    Oracle--plsql游标创建和使用 为什么要游标: 先看这个: DECLARE v_empno emp.empno%type; v_ename emp.ename%type; BEGIN SEL ...

  7. oracle12c清理游标,Oracle专题12之游标

    示例:按职工的职称涨工资,总裁涨1000元,经理涨500元,其他员工涨300元. DECLARE --定义游标 CURSOR emp01_cursor IS SELECT empno, job FRO ...

  8. oracle中的cursor属性有哪些,Oracle学习11:游标(cursor)--显式游标隐式游标、游标四个属性、循环遍历...

    1.概述 上文PLSQL学习中提到的知识,可以发现,基本都可以通过Java等语言实现,而为了实现程序的可移植性,实际开发工作中我们也是如此做的. 那么PLSQL的重点是什么呢?接下来我们来介绍游标cu ...

  9. 【Oracle】Cursor(游标)

    [Oracle]Cursor(游标) Cursour(游标)是Oracle数据库中解析SQL和执行SQL的载体. Shared Cursor 定义 Shared Cursor 是指缓存在库缓存里 SQ ...

最新文章

  1. 《深入理解计算机系统》第十章——系统级I/0
  2. 移远NB-IOT BC28模块模组简介和实际应用方向详解
  3. AcWing算法提高课 Level-3 第二章 搜索
  4. 【机器学习】创建自己的电影推荐系统
  5. Xcode 4.4 的新特性 | LLVM 4.0 的新语法
  6. 随机抽样java_java生成抽样随机数的多种算法
  7. WdatePicker 设置日期第一个比第二个的日期小
  8. PC-[WIN7]此计算机无法联接家庭组
  9. Navicat 用ssh通道连接时总是报错 (报错信息:SSH:expected key exchange group packet form serve...
  10. VScode编辑器设置中文界面教程
  11. cisco 模拟器安装及交换机的基本配置实验心得_网络工程师的Python之路 -- 自动监测网络配置变化...
  12. python常用的十进制、16进制、字符串、字节串之间的转换
  13. 西北乱跑娃 --- python繁体字简体字互转第三方库
  14. keil4和keil5如何兼容使用
  15. 学习PMbok对pmp考试的认知理解和itto输入输出的整理笔记
  16. 星际争霸2 AI开发
  17. 电脑换硬盘要重装系统吗
  18. 速度来看mac电脑怎么彻底关闭系统更新
  19. 计算机专业四次评估,一直强才是真的强,四次评估结果看,哪些大学才是计算机专业强校...
  20. 如何设计网页?快速制作网页秘诀!

热门文章

  1. SQL Server远程部署
  2. android10分区镜像,分区和映像  |  Android 开源项目  |  Android Open Source Project
  3. linux fedora yum安装docker-ce
  4. 【收藏】webpack configuration.module has an unknown property ‘loaders‘. These properties arevalid: 解决办法
  5. 【网址收藏】podman安装及使用简单介绍
  6. linux userdel删除用户命令
  7. Java并发编程--不要使用字符串常量作为synchronized锁对象
  8. Redis集群分片存储原理图
  9. 幂等性概念及数据库乐观锁机制
  10. 解决导入的maven聚合工程中子模块项目不显示