Oracle 10g中利用哈希函数提高查询速度

2016-02-19 13:55 10 1 收藏

今天天气好晴朗处处好风光,好天气好开始,图老师又来和大家分享啦。下面给大家推荐Oracle 10g中利用哈希函数提高查询速度,希望大家看完后也有个好心情,快快行动吧!

【 tulaoshi.com - 编程语言 】

当数据存储在一个普通表中的时候,这些记录将以插入到数据库时的顺序物理地保存到分配的块中。

例如,假如有一个用于存储员工信息的表,那么员工姓名将会按照插入到表的顺序存储在表中。 假如员工记录非常多的话,那么数据表的响应速度就会逐渐变慢。你可以通过选择值相对等分布的一列(如员工的部门编号)并建立一个簇表来提高查询员工的速度。 在簇表中,假如员工属于同一个部门,那么它们的记录将物理地存储在同一系列的块中。这样就可以提高查找员工信息的速度,这是因为在检索某个特定部门的员工时,需要读取数据库块的数量减少了。

而在非簇表中查找员工,就可能需要对每个数据库块进行访问。 当表中存在大量键值的时候,你就会开始发现由于存在许多簇块而导致的性能问题。避免这个问题的一个方法就是使用一个哈希函数来约束簇块的数量。哈希函数将会给定一个数值用来限定簇块数量的预计范围,但它得到的值是相对等分布的。

例如你可以创建一个哈希函数,只比较部门编号的最后两位。 哈希函数中存在的一个问题就是函数值会打乱记录原本的顺序。你可以通过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

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

(

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)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

values ('4111111111111111','20050131000123',57.99);

insert into credit_orders (card_no,transdate,amount)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

values ('4111111111111111','20050130071216',16.59);

insert into credit_orders (card_no,transdate,amount)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

values ('4111111111111111','20050131111111',39.00);

insert into credit_orders (card_no,transdate,amount)

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/bianchengyuyan/)

values ('4111111111111111','20050130081001',25.16);

可以看到我在这里使用了一个新函数ORA_HASH 来为信用卡建立一个哈希数值。现在,你可以非常简单地对某个信用卡数据进行查询,并返回自动排序后的结果。

来源:https://www.tulaoshi.com/n/20160219/1605689.html

延伸阅读
目标 数据库恢复 恢复控制文件 不完全恢复的原因 使用EM完成不完全恢复 使用RMAN完成不完全恢复 使用SQL完成不完全恢复 在RESETLOGS操作之后完成数据库恢复 10g有三种方法恢复:1.传统的用户管理恢复过程2.RMAN 3.使用EM 理解Restore(重建)和Recovery(恢复)过程 重建:包括复制必...
     在前面的文章,我为大家介绍了如何使用Oracle 10g的虚拟私有数据库特征(VPD)掩藏某列数据TechRepublic的成员BrooklynPennyPincher建议我写一篇关于VPD与关系视图的比较文章。      前面文章中小技巧的任务是假如department_id的值等于60,那么掩藏报告中的salary和commission_pct列。因为谓词...
在linux下安装oracle是一件令人生畏的事情,其复杂程度远远超过安装linux操作系统本身。如果能够进行成功的安装oracle,那么同时也就顺便掌握了linux一些技术。本文介绍在redhat linux 下安装oracle 10g 的方法。在这里说明一下,Oracle 10g的g是grid 的缩写,意为网格,目前较为前沿的网络计算技术。 Oracle 10g 对软硬件的要求都非常的高,...
1。帐号和口令设置 要选择用户SYS、SYSTEM、DBSNMP、SYSMAN使用相同的口令,那就选择“所有账户使用同一口令”。 BI用户,口令ch51*****,SCOTT用户。以上全部为同一个口令ch5******* 这里选择“使用不同的口令”,分别设置用户的口令: SYS用户的口令为ORACLE SYSTEM用户的口令为MANAGER DBSNMP用户的口令为DBSNMP SYSMAN用户的口令...
Oracle的虚拟私有数据库特性(也称作细颗粒度存取控制)对诸如SELECT等数据治理语言DML语句提供行级安全性检查。PL/SQL策略函数和某个数据表相关联,这个函数可以检查当前用户的上下文背景并添加查询中WHERE语句的条件(断言),一个用户或者应用可以这样来写: SELECT * FROM employees; 但是实际上oracle将会执行这样的语句: SELECT * FROM...

经验教程

156

收藏

14
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部