网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  使用"oracle"解析函数快速检查序列间隙     
  文章作者:未知  文章来源:赛迪网技术社区  
  查看:75次  录入:管理员--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中使用自治事务保存日志表条目
  相关文档
讲解dbms_stats的分析表与备份分析信息 08-06
怎样在oracle 10g存储过程中log错误行 04-16
在oracle中重新编译所有无效的存储过程 03-14
Oracle中利用哈希函数提高查询速度 04-11
实例解析将审计跟踪保存在一个系统表内 09-01
讲解oracle中job与存储过程的接合用法 03-13
Oracle中spfile和pfile之间区别和联系 05-13
查看前五个最占用cpu的oracle会话进程 02-01
oracle failsafe与rac两者之间的不同之处 05-13
不影响primary database也可以打开standby 02-28
详细讲解oracle数据库灾难防护的核心技术 02-29
0racle-07445 错误的解决方法和处理过程 09-29
从问题入手帮你解决Oracle杀死死锁进程 05-27
Oracle智能代理与OMS的问题解答 05-27
初学者必读:sqlplus的autotrace的设置 07-24
如何在oracle层次查询中给siblings排序 04-28
关于Oracle中表外键更名规则详细介绍 04-11
Oracle中查找和删除重复记录方法简介 04-11
讲解如何用组来保证Oracle数据库的安全 06-03
个人经验:怎样杀死"oracle"的死锁进程 02-01
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息