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

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

一个显而易见的方式就是用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. 句法分析常用算法框架以及NLPIR、Dependency Viwer
  2. 坐标下降+随机梯度下降
  3. 在VSO8中使用QT
  4. Linux-Iptables-Memcached实现内网转发连接
  5. python界面散点图_Python数据可视化——散点图
  6. MySQL高级配置(二)详细介绍
  7. 理解杀毒软件技术的意义 脱壳、虚拟、启发式介绍
  8. Discrete Log Algorithms :Baby-step giant-step
  9. Logistic 梯度法进行分类
  10. oracle还原 ora 39111,在server2008上进行impdp引发的(ORA-39070)的问题
  11. Python字符串格式()
  12. 【vscode】去除黄色波浪下划线
  13. win10系统自动安装应用商店(Microsoft Store)方法步骤
  14. 运动控制器RTEX总线使用入门
  15. Android打开项目一直build的问题解决
  16. 快速故障定位 看联想和Riverbed如何演绎?
  17. 2021智能零售领域最具商业合作价值企业盘点
  18. python电影爬虫背景介绍_Python爬虫入门教程01之爬取豆瓣Top电影
  19. 一个P2P未跑路平台老板的自白
  20. javaScript内存溢出vue-cli3解决方案

热门文章

  1. 分页加载总页数计算公式
  2. LockSupport类中的park()和unpark()
  3. 线程间的通信之wait和notify的使用
  4. MyBatis数据库链接池源码分析
  5. 分布式文件存储FastDFS之安装Nginx实现文件访问
  6. Spring Cloud Eureka详解
  7. jdk优先级队列、延迟队列原理
  8. 慎重!物联网时代情趣用品真的适合联网么?
  9. Python nose测试工具报ImportError: No Module named 错误
  10. Struts2.0 + Spring2.5 + Hibernate3.3开发环境的配置(1)