网站首页
JSP空间
动态资讯
开源项目
技术文档
资源下载
J2EE资源
客户论坛
在线支付
 
  技术文档>>数据库技术>>Oracle技术>>Oracle开发>查看文档  
  利用Oracle解析函数快速检查序列间隙     
  文章作者:未知  文章来源:未知  
  查看:138次  录入:管理员--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数据库中重复没用的数据 09-10
脚本示例:查看数据库中有无多余的索引sql 07-01
理解和使用Oracle 8i分析工具-LogMiner 01-15
Oracle数据库中通过扩展SQL跟踪数据 04-11
Oracle与Access表之间的导入和导出 04-23
全面解析oracle数据库中管理实例的方法 (1) 04-24
利用Oracle解析函数快速检查序列间隙 04-11
怎样才能dump oracle数据库的内部结构 04-07
Oracle 11g 新版数据库新增400余项技术 09-01
解析:怎样查出前台正在发出的sql语句 08-05
经验总结:sql server与oracle的数据同步 06-12
通过分析SQL语句的执行计划优化SQL(一) 08-05
讲解oracle数据库在nt平台下的系统优化 (1) 01-29
详细讲解oracle数据库管理员认证方法 04-17
在存储过程中拥有"role"权限的特殊性 03-17
浅析Oracle数据库的最大可用性体系结构 07-07
教你快速掌握如何使用"opatch"打补丁 03-10
决定用户对全部对象名引用的三种数据库链 02-28
相关的技术培训(oracle) 01-15
Oracle 9i 数据库移动过程 04-11
返回首页 | 关于我们 | J网章程 | JSP空间合租 | 客服中心 | 免责声明 | 常见问题 | 参观机房
本站主机空间代理至厦门市华众网络科技有限公司
《中华人民共和国增值电信业务经营许可证》
编号:闽B2-20050079
@2005-2008福建JSP技术网 版权所有 闽ICP备05000928号
厦门(总部):13616026886 福州:0591-87655121
邮箱:admin@fjjsp.com 站长QQ,点击这里给我发消息