网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > 数据库 > Oracle教程
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
数据库:数据库教程,数据库技巧,Oracle教程,MySQL教程,Sybase教程,Access教程,DB2教程,数据库安全,数据库文摘
本月文章推荐
.某人的oracle9i学习笔记,与大家.
.Oarcle学习笔记之.
.Oracle PL/SQL集合增强.
.实用心得:虚拟机下Oracle的安装.
.每个Oracle DBA都应该遵从的调优.
.Oracle数据库技术(34).
.在RedHat7.0下安装Oracle的经历.
.Oracle分层管理器的技术原理及应.
.ORACLE中的物化视图.
.pl/sql developer工具几点妙用.
.互连环境下实现ORACLE数据库分布.
.Linux 上的邮件网关(杀病毒)An.
.Oracle rac安装过程详解(四).
.修改oracle监听占用的8080端口.
.Oracle9i中取得建表和索引的DDL语.
.Install oracle client on Solar.
.Logon Trigger Example 登陆例子.
.SQL Server到Oracle连接服务器的.
.在oracle中编写树级代码.
.解决物化视图刷新过程中的约束冲.

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

发表日期:2008-2-9


数据库表格中经常用到值序列。无论是作为数据本身自然产生的,还是由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中实现大量数据快速转移数据 人气:535
下一篇:ORACLE 11g新特性简介 人气:1198
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐