oracle创建哈希分布表,Oracle分区表,哈希分区的新建与增加

当Oracle表数据量巨大时,可通过分区提高查询效率。本文介绍了哈希分区的适用场景,新建分区的步骤,包括在线重定义方法,并展示了如何为已存在的哈希分区表增加分区。
摘要由CSDN通过智能技术生成

一、背景知识

Oralce中的一张表数据量达到亿数量级后或是单表达到2G大小,查询效率似乎会明显下降。需要通过分区的方式,从行的维度对表进行划分,避免单表数据量过大

分区方法有下面几类:

范围,最常见,按照某列数据的范围分区,比如按时间分区

哈希,对于数据规律性不强,或者取值范围难以确定的,推荐哈希法,强行进行分区。分区个数需设置成2的幂次

列表,类似枚举,需事先知道字段的精确值

混合,上述各种组合

oracle 11g又新增了几种分区方法,如下:

引用分区,父表的外键作为关键字建立分区,则子表可以以同样的方式分区

虚拟列分区,通过表中字段的运算结果进行分区

间隔分区,范围分区的变种,范围固定且分区可自动扩展

系统分区,insert和select时,全完手工指定分区

参考资料:http://space.itpub.net/7607759/viewspace-260278

http://tech.it168.com/db/2008-03-24/200803241734089.shtml

二、新建分区

这里就写下在线重定义的方法,离线的就不写了。

1.新建一张表

CREATE TABLE T_HASH (ID NUMBER PRIMARY KEY, TIME DATE);

2.往里面插测试数据

3.测试权限

EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(userName,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值