网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  使用"oracle"解析函数快速检查序列间隙     
  文章作者:未知  文章来源:赛迪网技术社区  
  查看:104次  录入:管理员--2008-02-02  
 

数据库表格中经常用到值序列。无论是作为数据本身自然产生的,还是由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"下导出某用户所有表的方法    下一篇: 在oracle中使用自治事务保存日志表条目
  相关文档
开发篇之 Oracle触发器心得体会 05-27
深入探讨如何解决数据库中的死锁问题 04-08
探讨基于不绑定变量与绑定变量的柱状图作用 (1) 03-10
oracle数据库中如何根据时间来执行job 05-13
教你使用智能优化器提高Oracle性能极限 05-27
详细讲解各种数据库使用jdbc连接的方式 03-28
讲解oracle show parameter命令的小技巧 07-30
如何使用ref cursor处理oracle的结果集 03-26
oracle数据库中为什么会产生回滚与前退 04-18
如何在SQL Server中构建并利用UDF表格 07-07
了解国外公司的Oracle DBA面试试题 05-13
快速掌握列值掩码技术隐藏敏感数据 11-15
Oracle如何对CLOB行字段来执行全文检索 06-10
oracel监听器启动后为什么会自动停掉 04-09
Oracle的两个重要文件:TNSNAMES.ORA 05-13
两个有用oracle运算:intersect和minus运算 08-14
怎样在数据字典中直接修改oracle表列名 11-15
Oracle中对COLUMNS_UPDATED()返回值解析 06-17
oracle数据库中关于"null"排序的问题 01-25
轻松掌握"lag"与"lead"分析函?的用法 02-29
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息