数据库表格中经常用到值序列。无论是作为数据本身自然产生的,还是由 的序列对象分配的,它的目的就是用一个唯一的、递增的数字给每一行编号。

在编号的过程中,产生间隙的原因多种多样。如果一个过程从一个序列中挑选某个数字,定为本地变量,但是从来不用它,这个数字就丢失了。它将不能再返回到原序列中,结果就造成数值序列中存在一个间隙。关系型数据库模型中不必担心这一点。但是有时候人们在意这一点,这些人想知道是哪些数字丢失了。

一个显而易见的方式就是用PL/SQL,在已排序指针中循环,并且用一个本地变量进行,把每一个数值与其前一行的进行比较。这种方法的问题在于效率很低,速度很慢。另外一个不常用的解决办法就是对表格做一个自合并,实质也就是用某种标准使每一行与其前一行相匹配。这种方法很难编写代码。

的解析函数为检查间隙提供了一种要快捷得多的方法。它们使你在使用完整的、面向集合的SQL处理的同时,仍然能够看到下一个行(LEAD)或者前一行(LAG)的数值。

下面是这些函数的格式:

{LEAD | LAG} (value_expression, offset, default)

OVER ([PARTITION BY expr] ORDER BY expr)

通常,value_expression是一个你想要检索的数据列。参数offset是指你想要往前或往后读取的行数,default则是到达任意一个分区的开头或者结尾(即没有与之相匹配的行)时返回的数值。

脚本是一系列从工作地传感器自动收集来的数据。传感器装置自动给每一个测量值编上号,我们要找出结果有没有缺失。

我们将数据按照测量值编号排序,运用LAG函数,把偏移量设置为1,使得每一行与其前一行对应起来。第一行将没有对应量,所以相应地,将返回默认值0。因为间隙不可能发生在第一行,所以我们通过之前要求测量值大于0而将其删除。

剩下的就是一组虚拟的行,显示的是前一行的测量值编号(“before_gap”)和当前行的测量值编号(“after_gap”)。如果两者之差大于1,就说明这两行之间存在间隙。

同时也要注意到,WITH子句在查询开始的时候把解析子查询命名为“aquery”。那么我们就可以在主SELECT 语句中的WHERE 子句中访问“aquery”中的数列。

【责编:Peng】

--------------------next---------------------

oracle快速解析,教你用Oracle解析函数快速检查序列间隙相关推荐

  1. oracle事件的特点,ORACLE 深入解析10053事件(1)

    本帖最后由 leonarding 于 2013-2-24 15:57 编辑 新年新说: 新年伊始,2012年过去了,我们又踏上了2013年的,回顾2012我们付出了很多,辛勤和汗水换来了知识和友谊,当 ...

  2. oracle resp_cpu含义,【原创】ORACLE 深入解析10053事件

    [原创]ORACLE 深入解析10053事件 发布时间:2020-08-09 16:47:25 来源:ITPUB博客 阅读:95 作者:kunlunzhiying 新年新说: 新年伊始,2012年过去 ...

  3. oracle无法解析连接符,oracle无法解析连接字符串,请教

    oracle无法解析连接字符串,请教 C# code: string StrConnection = "Server=127.0.0.1;Data Source=kagami;User ID ...

  4. oracle dg 搭建方式,Linux平台 Oracle 11g DG测试环境快速搭建参考

    环境现状: 两台虚拟主机A和B: 1. A机器已安装ASM存储的Oracle 11g 实例 2. B机器已安装系统,配置以及目录结构均和A机器保持一致 /u01 + 3块ASM盘 DG部署规划: pr ...

  5. Javamysql语法转化oracle_MyBatis项目实战 快速将MySQL转换成Oracle语句

    一.前言 因项目需求,小编要将项目从mysql迁移到oracle中 ~ 现在将完成 基于MyBatis-Plus将项目中的MySQL语句全部转换成Oracle语句 大概实现步骤: 将项目改成支持双库配 ...

  6. oracle静默创建实例linux,linux CentOS7下快速静默安装Oracle11GR2数据库并创建实例

    linux CentOS7下快速静默安装Oracle11GR2数据库并创建实例 本文章适合已经熟悉安装过程,需要快速部署使用 初学者建议分步学习:https://edu.51cto.com/cours ...

  7. Oracle硬解析,软解析,软软解析介绍

    Oracle数据库中的CURSOR分为两种类型:Shared Cursor 和 Session Cursor 1,Shared Cursor Oracle里的第一种类型的Cursor就是Shared ...

  8. oracle中undo解析,oracle undo解析

    oracle undo解析 Undo是干嘛用的? 在介绍undo之前先说一下另外一个东西 transaction ,翻译成交易或事务.我们在进行一个事务的过程中需要申请许多资源,一个复杂的事务也需要很 ...

  9. oracle游标增大,ORACLE 硬件解析高的问题解决--修改SESSION_CACHED_CURSORS游标缓存参数...

    Oracle AWR报告中,数据库硬解析偏高,SQL执行过程中硬解析占比过高,影响SQL执行效率,该问题多数是 session_cached_cursors游标缓存不足引起的,该参数默认值为50,可以 ...

  10. oracle 10046 看锁,Maclean教你读Oracle 10046 SQL TRACE

    有同学一直向Maclean反应希望做一期10046 SQL trace的教程, 正好这几天有空 我们就理一理. 为什么我们要使用10046 trace? 10046 trace帮助我们解析 一条/多条 ...

最新文章

  1. 自定义注解!绝对是程序员装大佬的利器!!
  2. (asp.net)百度浏览器Cookie的神奇bug
  3. 智能车竞赛技术报告 | 节能信标组 - 洛阳理工学院 - Since 2021
  4. php获取域名与路径
  5. 模型融合之stacking方法
  6. android studio 第一个程序显示radle d 'https://services.gradle.org/distributions/gradle-5.4.1-all.zip'.
  7. JavaFX技巧17:带有AnchorPane的动画工作台布局
  8. Flex 学习站点汇总,(FLEX学习站点、博客、论坛)
  9. IIS服务器应用程序不可用的解决办法
  10. HDU1003:Max Sum(简单dp)
  11. Android ScrollView 使用总结
  12. sftp连不上服务器 vscode_vscode+sftp 开发模式环境的同步
  13. 2022-基于树木形态和有限状态机的森林火灾蔓延实时三维可视化
  14. 海滩xxxx_人工智能处理海洋垃圾:借助数据清理世界各地的海滩
  15. 用canvas制作的躲避球小游戏html5源码
  16. 电脑桌面计算机找不到,电脑桌面没有了怎么恢复?电脑桌面没有了的恢复方法...
  17. 如何实现select * exclude column
  18. 计算机理论和地理的关系,计算机辅助地理教学的理论和实践
  19. wpa_supplicant的用法
  20. 00007__点阵字体(位图)和TrueType字体

热门文章

  1. Android连接数据库的问题
  2. Linux上安装GCC编译器过程实录
  3. CnForums1.0 Alpha RC1 发布
  4. 软件设计原则(六) 合成复用原则
  5. SpringBoot中的定时任务和异步任务
  6. Spring整合MyBatis原理之MapperScannerConfigurer(一)
  7. css 为什么给span加vertical-align: middle不起作用?
  8. 为何区块链能成为金融行业的香饽饽?只因这5个关键因素!
  9. day6Linux命令-设置别名
  10. 初学Rman 写的备份脚本