oracle是甲骨文公司出品的一个大型的关系型数据库,提供了非常多的操作数据的函数,在我们日常开发中,当一个表的数据量非常大时,比如日志表,表的操作性能会越来越低,并且需要更好的维护新老数据时,这时我们会对表进行分区,以便更好的解决问题
1、分区表关键字:
PARTITION 分区
RANGE 范围
LIST 列表
HASH 哈希
INTERVAL 自动扩展分区
SUBPARTITION 子分区
2、建表语句以及分区类型
CREATE TABLEtableName
(
DATE_ID NUMBER(8),
HOUR_ID NUMBER(2),
STATUS VARCHAR2(1),
DATA_TIME DATE DEFAULT SYSDATE
)
--按时间分区,每天自动创建一个分区 'day' 表示每天 ‘mouth’表示每月 NUMTODSINTERVAL 是一个时间函数
PARTITION BY RANGE (DATA_TIME)INTERVAL(NUMTODSINTERVAL(1,'day'))
(
PARTITION P20170501_LS VALUES LESS THAN (TO_DATE('2017-05-01','YYYY-MM-DD')) TABLESPACE USERS
);
--创建列表分区,选择字段值少的字段进行分区,表结构不变
PARTITION BY LIST (STATUS)
(
PARTITION p_0 VALUES('0')TABLESPACE USERS,
PARTITION p_1 VALUES('1')TABLESPACE USERS
);
--创建hash分区,根据hash算法,在没有哪个列字段条件合适情况下
PARTITION BY HASH (DATE_ID)PARTITIONS 4 --分为4个区
或者是
PARTITION BY HASH (DATE_ID)
(
PARTITION p_0 TABLESPACE USERS,
PARTITION p_1 TABLESPACE USERS
);
--创建范围分区下带列表子分区
partition by range (SALES_DATE) SUBPARTITION BY list (STATUS)
(
PARTITION P1 VALUES LESS THAN(TO_DATE('2017-05-01','YYYY-MMDD'))TABLESPACE USERS
(
subpartition P1SUB1 VALUES ('0') TABLESPACE USERS,
subpartitionP1SUB2 VALUES ('1') TABLESPACE USERS
)
);
ALTER TABLE tableName drop PARTITION partitionName;
ALTER TABLE tableName drop subpartition subpartitionName;
CREATE INDEX IX_USER_NAME ON tableName(列名1) LOCAL;
说明:
A、分区表指定了分区名进行查询时,条件中没有索引列也是在这个指定分区内进行查找
B、分区表在不指定分区名进行查询时,条件中没有索引的话将进行全表扫描,有索引的话为各个分区内索引扫描
C、分区表不指定分区名进行查询时,条件中有分区键,无索引时,也是在单个分区内进行查找,有索引则在单个分区内索引查找
D、分区表不指定分区名进行查询时,条件中有分区键,并且为索引时,是在单个分区内索引查找
本地索引特点:
1. 本地索引一定是分区索引,分区键等同于表的分区键,分区数等同于表的分区说,一句话,本地索引的分区机制和表的分区机制一样。
2. 如果本地索引的索引列以分区键开头,则称为前缀局部索引。
3. 如果本地索引的列不是以分区键开头,或者不包含分区键列,则称为非前缀索引。
4. 前缀和非前缀索引都可以支持索引分区消除,前提是查询的条件中包含索引分区键。
5. 本地索引只支持分区内的唯一性,无法支持表上的唯一性,因此如果要用本地索引去给表做唯一性约束,则约束中必须要包括分区键列。
6. 本地分区索引是对单个分区的,每个分区索引只指向一个表分区,全局索引则不然,一个分区索引能指向n个表分区,同时,一个表分区,也可能指向n个索引分区,对分区表中的某个分区做truncate或者move,shrink等,可能会影响到n个全局索引分区,正因为这点,本地分区索引具有更高的可用性。
7. 位图索引只能为本地分区索引。
8. 本地索引多应用于数据仓库环境中。
CREATEINDEX I_ID_GLOBAL ON TEST(ID) GLOBAL
全局索引特点:
1.全局索引的分区键和分区数和表的分区键和分区数可能都不相同,表和全局索引的分区机制不一样。
2.全局索引可以分区,也可以是不分区索引,全局索引必须是前缀索引,即全局索引的索引列必须是以索引分区键作为其前几列。
3.全局分区索引的索引条目可能指向若干个分区,因此,对于全局分区索引,即使只截断一个分区中的数据,都需要rebulid若干个分区甚至是整个索引。
4.全局索引多应用于oltp系统中。
5.全局分区索引只按范围或者散列hash分区,hash分区是10g以后才支持。
6.oracle9i以后对分区表做move或者truncate的时可以用updateglobal indexes语句来同步更新全局分区索引,用消耗一定资源来换取高度的可用性。
7.表用a列作分区,索引用b做局部分区索引,若where条件中用b来查询,那么oracle会扫描所有的表和索引的分区,成本会比分区更高,此时可以考虑用b做全局分区索引。
全局索引:与本地分区索引不同的是,全局分区索引的分区机制与表的分区机制不一样。全局分区索引全局分区索引只能是B树索引,到目前为止(10gR2),oracle只支持有前缀的全局索引。
另外oracle不会自动的维护全局分区索引,当我们在对表的分区做修改之后,如果执行修改的语句不加上updateglobal indexes的话,那么索引将不可用