MySQL 指定各分区路径
可以针对分区表的每个分区指定各自的存储路径,对于innodb存储引擎的表只能指定数据路径,因为数据和索引是存储在一个文件当中,对于MYISAM存储引擎可以分别指定数据文件和索引文件,一般也只有RANGE、LIST分区、sub子分区才有可能需要单独指定各个分区的路径,HASH和KEY分区的所有分区的路径都是一样。RANGE分区指定路径和LIST分区是一样的,这里就拿LIST分区来做讲解。
一、MYISAM存储引擎CREATETABLEth(idINT,adateDATE)engine='MyISAM'PARTITIONBYLIST(YEAR(adate))(PARTITIONp1999VALUESIN(1995,1999,2003)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx',PARTITIONp2000VALUESIN(1996,2000,2004)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx',PARTITIONp2001VALUESIN(1997,2001,2005)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx',PARTITIONp2002VALUESIN(1998,2002,2006)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx');
注意:MYISAM存储引擎的数据文件和索引文件是分库存储所以可以为数据文件和索引文件定义各自的路径,INNODB存储引擎只能定义数据路径。
二、INNODB存储引擎CREATETABLEthex(idINT,adateDATE)engine='InnoDB'PARTITIONBYLIST(YEAR(adate))(PARTITIONp1999VALUESIN(1995,1999,2003)DATADIRECTORY='/data/data',PARTITIONp2000VALUESIN(1996,2000,2004)DATADIRECTORY='/data/data',PARTITIONp2001VALUESIN(1997,2001,2005)DATADIRECTORY='/data/data',PARTITIONp2002VALUESIN(1998,2002,2006)DATADIRECTORY='/data/data');
指定路径之后在原来的路径中innodb生成了4个指向数据存储的路径文件,myisam生成了一个th.par文件指明该表是分区表,同时数据文件和索引文件指向了实际的存储路径。
三、子分区1.子分区
CREATETABLEtb_sub_dir(idINT,purchasedDATE)ENGINE='MYISAM'PARTITIONBYRANGE(YEAR(purchased))SUBPARTITIONBYHASH(TO_DAYS(purchased))(PARTITIONp0VALUESLESSTHAN(1990)(SUBPARTITIONs0DATADIRECTORY='/data/data_sub1'INDEXDIRECTORY='/data/idx_sub1',SUBPARTITIONs1DATADIRECTORY='/data/data_sub1'INDEXDIRECTORY='/data/idx_sub1'),PARTITIONp1VALUESLESSTHAN(2000)(SUBPARTITIONs2DATADIRECTORY='/data/data_sub2'INDEXDIRECTORY='/data/idx_sub2',SUBPARTITIONs3DATADIRECTORY='/data/data_sub2'INDEXDIRECTORY='/data/idx_sub2'),PARTITIONp2VALUESLESSTHANMAXVALUE(SUBPARTITIONs4DATADIRECTORY='/data/data_sub3'INDEXDIRECTORY='/data/idx_sub3',SUBPARTITIONs5DATADIRECTORY='/data/data_sub3'INDEXDIRECTORY='/data/idx_sub3'));
2.子分区再分
CREATETABLEtb_sub_dirnew(idINT,purchasedDATE)ENGINE='MYISAM'PARTITIONBYRANGE(YEAR(purchased))SUBPARTITIONBYHASH(TO_DAYS(purchased))(PARTITIONp0VALUESLESSTHAN(1990)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx'(SUBPARTITIONs0DATADIRECTORY='/data/data_sub1'INDEXDIRECTORY='/data/idx_sub1',SUBPARTITIONs1DATADIRECTORY='/data/data_sub1'INDEXDIRECTORY='/data/idx_sub1'),PARTITIONp1VALUESLESSTHAN(2000)DATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx'(SUBPARTITIONs2DATADIRECTORY='/data/data_sub2'INDEXDIRECTORY='/data/idx_sub2',SUBPARTITIONs3DATADIRECTORY='/data/data_sub2'INDEXDIRECTORY='/data/idx_sub2'),PARTITIONp2VALUESLESSTHANMAXVALUEDATADIRECTORY='/data/data'INDEXDIRECTORY='/data/idx'(SUBPARTITIONs4DATADIRECTORY='/data/data_sub3'INDEXDIRECTORY='/data/idx_sub3',SUBPARTITIONs5DATADIRECTORY='/data/data_sub3'INDEXDIRECTORY='/data/idx_sub3'));
也可以给个分区指定路径后再给子分区指定路径,但是这样没有意义,因为数据的存在都是由子分区决定的。
注意:
1.指定的路径必须存在,否则分区无法创建成功
2.MYISAM存储引擎的数据文件和索引文件是分库存储所以可以为数据文件和索引文件定义各自的路径,INNODB存储引擎只能定义数据路径
参考:
RANGE分区:h ttp://w ww.cnb logs.com/ch enmh/p/5627912.html
LIST分区:h ttp://w ww.cnbl ogs.com/che nmh/p/5643174.html
COLUMN分区: http://w ww.c nblogs.com/c henmh/p/5630834.html
HASH分区:ht tp://w ww.cnb logs.com/ch enmh/p/5644496.html
KEY分区:htt p://ww w.cnblo gs.com/ch enmh/p/5647210.html
子分区:htt p://w ww.cnblo gs.com/che nmh/p/5649447.html
分区建索引:h ttp://w ww.cn blogs.com/chenmh/p/5761995.html
分区介绍总结:ht tp://w ww.cnb logs.com/chen mh/p/5623474.html
总结通过给各个分区指定各自的磁盘可以有效的提高读写性能,在条件允许的情况下是一个不错的方法。
声明:本站所有文章资源内容,如无特殊说明或标注,均为采集网络资源。如若本站内容侵犯了原著者的合法权益,可联系本站删除。