博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Oracle分区表,哈希分区的新建与增加
阅读量:6308 次
发布时间:2019-06-22

本文共 1303 字,大约阅读时间需要 4 分钟。

一、背景知识

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

分区方法有下面几类:

  • 范围,最常见,按照某列数据的范围分区,比如按时间分区
  • 哈希,对于数据规律性不强,或者取值范围难以确定的,推荐哈希法,强行进行分区。分区个数需设置成2的幂次
  • 列表,类似枚举,需事先知道字段的精确值
  • 混合,上述各种组合

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

  • 引用分区,父表的外键作为关键字建立分区,则子表可以以同样的方式分区
  • 虚拟列分区,通过表中字段的运算结果进行分区
  • 间隔分区,范围分区的变种,范围固定且分区可自动扩展
  • 系统分区,insert和select时,全完手工指定分区

参考资料:

二、新建分区

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

1.新建一张表

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

2.往里面插测试数据

3.测试权限

EXEC DBMS_REDEFINITION.CAN_REDEF_TABLE(userName, 'T_HASH', DBMS_REDEFINITION.CONS_USE_PK);

如果提示没有权限,通过dba账户添加当前账户权限,或者直接用dba账户操作

4.建一个与原表结构一样的临时表,需在临时表建分区

CREATE TABLE T_TMP (ID NUMBER PRIMARY KEY, TIME DATE)partition by hash (ID)(  partition p1 tablespace spaceName,  partition p2 tablespace spaceName,);

5. 在线重定义

表的在线重定义

EXEC DBMS_REDEFINITION.START_REDEF_TABLE(userName, 'T_HASH', 'T_TMP');

数据同步,保证操作过程中,临时表和原表的数据一致性

execute dbms_redefinition.sync_interim_table(userName,'T_HASH','T_TMP');

执行结束

EXEC DBMS_REDEFINITION.FINISH_REDEF_TABLE(userName, 'T_HASH', 'T_TMP');

6.检查结果

SELECT COUNT(1) FROM T_HASH;SELECT COUNT(1) FROM T_HASH PARTITION (P1);SELECT COUNT(1) FROM T_HASH PARTITION (P2);

7.删除临时表

参考资料:

三、增加分区

对于哈希分区,一条SQL搞定:

ALTER TABLE tableName ADD PARTITION partitionName;

 

转载于:https://www.cnblogs.com/todsong/archive/2012/08/26/2657158.html

你可能感兴趣的文章
并查集模板
查看>>
RESTful Mongodb
查看>>
BZOJ3237:[AHOI2013]连通图(线段树分治,并查集)
查看>>
如何提高Ajax性能
查看>>
Android--自定义加载框
查看>>
LINUX下 lamp安装及配置
查看>>
BZOJ3105 [cqoi2013]新Nim游戏
查看>>
困惑的前置操作与后置操作
查看>>
SDNU 1269.整数序列(水题)
查看>>
BZOJ 2118 Dijkstra
查看>>
Go语言基础之结构体
查看>>
SpringCloud:Eureka Client项目搭建(Gradle项目)
查看>>
jqueryValidate
查看>>
ATL使用IE控件,并且屏蔽右键
查看>>
Jenkins
查看>>
linux下使用screen和ping命令对网络质量进行监控
查看>>
数据库设计技巧
查看>>
css定位概述
查看>>
C# 动态修改配置文件 (二)
查看>>
BOM:文档对象模型 --树模型
查看>>