网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  利用Oracle解析函数快速检查序列间隙     
  文章作者:未知  文章来源:未知  
  查看:125次  录入:管理员--2007-04-11  
  数据库表格中经常用到值序列。无论是作为数据本身自然产生的,还是由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”中的数列。

 
 
上一篇: Oracle 8 资料库函式库    下一篇: Oracle和MySQL的一些简单命令对比
  相关文档
oracle中sqlplus的常用指令收集与技巧 (1) 08-14
Oracle两个基本概念帮你了解体系结构 05-13
oracle 11g新特性──初始化文件的管理 02-25
三种Windows版本下教你如何卸载Oracle 05-27
从自动备份中恢复控制文件和spfile文件 11-22
oracle数据库删除表中重复记录的常见方法 08-04
重建oracle数据库控制文件的简单方法 05-13
在数据字典中直接修改表列的名称和顺序 06-17
在oracle 11g数据库中实现自我调整功能 07-24
如何将非归档日志模式切换到归档日志模式 05-13
oracle 11g最有特点的五大特性都有哪些 01-28
Oracle导出数据库结构到PowerDesigner 09-01
借助两个开发包在pl/sql中实现多进程通信 06-20
oracle数据库exp imp按用户导出导入实例 (1) 03-31
"physical standby"置于read/write状态 03-05
实例解析将审计跟踪保存在一个系统表内 09-01
怎样在数据字典中直接修改oracle表列名 11-15
oracle数据库中日期时间的操作比较和加减 05-12
如何在oracle中释放flash_recovery_area (1) 05-05
如何确定Oracle数据库表中重复的记录 01-15
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息