网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
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教程,数据库安全,数据库文摘
本月文章推荐
.ORACLE关于bin目录下各文件的意义.
.联机热备份与恢复实战.
.Oracle维护常用SQL语句(2).
.Oracle预定义角色.
.如何处理Oracle数据库中的坏块问.
.如何实现逻辑数据模型.
.Oracle应遵循的PL/SQL编码规则.
.postfix出现错误“fatal: unknow.
.oracle重装时问题解决方案.
.redflag认证系统管理部分笔记.
.Re: 关于oracle的备份与恢复问题.
.Oracle服务器性能调整攻略.
.为最佳性能而调优 Red Hat(2).
.ORACLE常见错误代码的分析与解决.
.ORACLE锁的管理.
.export/import技巧.
.Weblogic8配置Oracle数据库连接池.
.VB调用Oracle返回数据集.
.一次standby open read only 故障.
.oracle数据库备份与恢复 a piece.

用排序哈希簇来提升ORACLE查询速度

发表日期:2008-2-9



  当数据存储在一个普通表中的时候,这些记录将以插入到数据库时的顺序物理地保存到分配的块中。例如,假如有一个用于存储员工信息的表,那么员工姓名将会按照插入到表的顺序存储在表中。
  
  假如员工记录非常多的话,那么数据表的响应速度就会逐渐变慢。你可以通过选择值相对等分布的一列(如员工的部门编号)并建立一个簇表来提高查询员工的速度。
  
  在簇表中,假如员工属于同一个部门,那么它们的记录将物理地存储在同一系列的块中。这样就可以提高查找员工信息的速度,这是因为在检索某个特定部门的员工时,需要读取数据库块的数量减少了。而在非簇表中查找员工,就可能需要对每个数据库块进行访问。
  
  当表中存在大量键值的时候,你就会开始发现由于存在许多簇块而导致的性能问题。避免这个问题的一个方法就是使用一个哈希函数来约束簇块的数量。哈希函数将会给定一个数值用来限定簇块数量的预计范围,但它得到的值是相对等分布的。例如你可以创建一个哈希函数,只比较部门编号的最后两位。
  
  哈希函数中存在的一个问题就是函数值会打乱记录原本的顺序。你可以通过 ORDER BY来解决这个问题;但是,在很多情况下,记录数量是非常庞大的。在Oracle 10g 中,你可以将一个数据定义为“natural order” ,那么就可以不用经过排序而以你所希望的顺序来检索哈希簇的数据,从而解决了上面的提出问题。
  
  例如,假设你有一个信用卡业务的数据库。你决定以信用卡号作为簇主键将有利于数据的存储分布。但是,由于存在大量的信用卡号,所以可以使用一个哈希函数来约束簇块的数量。而且你希望在你的大部分报表中数据是按照时间顺序排列的,那么在进行每个查询操作时使用排序哈希簇,而不要使用ORDER BY。下面给出了相关语句:
  
  create cluster credit_cluster
  (
  card_no varchar2(16),
  transdate date sort
  )
  hashkeys 10000 hash is ora_hash(card_no)
  size 256;
  
  
  create table credit_orders
  (
  card_no varchar2(16),
  transdate date,
  amount number
  )
  cluster credit_cluster(card_no,transdate);
  
  
  alter session set nls_date_format = "YYYYMMDDHH24MISS";
  insert into credit_orders (card_no,transdate,amount)
  values ('4111111111111111','20050131000123',57.99);
  insert into credit_orders (card_no,transdate,amount)
  values ('4111111111111111','20050130071216',16.59);
  insert into credit_orders (card_no,transdate,amount)
  values ('4111111111111111','20050131111111',39.00);
  insert into credit_orders (card_no,transdate,amount)
  values ('4111111111111111','20050130081001',25.16);
  
  可以看到我在这里使用了一个新函数ORA_HASH 来为信用卡建立一个哈希数值。现在,你可以非常简单地对某个信用卡数据进行查询,并返回自动排序后的结果。
上一篇:深入了解Oracle 10g新型层次查询选项 人气:603
下一篇:为PL/SQL包创建ActiveX servers 人气:601
浏览全部Oracle教程的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐