教你用Oracle解析函数快速检查序列间隙

2016-01-29 14:39 25 1 收藏

教你用Oracle解析函数快速检查序列间隙,教你用Oracle解析函数快速检查序列间隙

【 tulaoshi.com - Oracle教程 】

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

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

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

Oracle的解析函数为检查间隙提供了一种要快捷得多的方法。它们使你在使用完整的、面向集合的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”中的数列。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com)

来源:http://www.tulaoshi.com/n/20160129/1493855.html

延伸阅读
最终效果图 原图 1、打开原图,按Ctrl+M打开曲线,面板上的通道下拉框,可以看到除了常用的RGB复合通道之外,还有红绿蓝三个单色通道,分别调整这三个单色通道的曲线,会改变图像中红绿蓝三色的比例关系,起到很好的精细调整色调的作用。 2、将这个点向上提,图像颜色偏红色,因为红色通道被提亮了,即增加了图像...
标签: autocad教程
本文由 中国 chqxu原创,转载须保留此信息 1)首先绘制垂直辅助线,以此交点为中线,作圆环。 screen.width*0.7) {this.resized=true; this.width=screen.width*0.7; this.alt='点击在新窗口查看全图\nCTRL+鼠标滚轮放大或缩小';}" border=0>  screen.width*0.7) {this.resized=true; this.width=screen.width*0.7; this.alt='点击在新...
原图 效果图 1 效果图 2 1、在PS打开素材图,修图的第一步是找到图片存在哪些问题,然后采取某手段来纠正,观察图片除了用肉眼处,我们更准确的应该借助于PS自带的工具来观察,比如直方图,信息面板等,这就是所谓数字化调整。从直方图上我们看到像素大量集中在中间调区和暗调区,高光区几乎没有,所以照片偏暗。 ...
标签: 电脑入门
从Excel2002开始新添了文本到语音的功能,这项功能使Excel可以将单元格中的数字或文字内容读出来,利用这个功能可以帮助校对表格中的内容输入是否正确。今天我们来了解一下这个功能的使用方法:打开工具菜单,选择语音项子菜单中的显示文本到语音工具栏命令,这个功能不是默认安装的,Excel会自动进行安装。安装好后,弹出文本到语音浮动工具栏...
标签: PS PS教程
(提示:括号内的快捷键在英文输入法状态下有效,可帮助你直接调用工具) 效果图: 1:打开图片 2:复制一层(ctrl+J),去色(shift+ctrl+U),图层模式改为滤色,不透明度50%左右 3:前景色设置为蓝色 4:选择加深工具 (shift+O),按如图位置加深 5:选择画笔工具 (B),选择柔角画笔 ,新建一层...

经验教程

672

收藏

58
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部