MySQL分区之指定各分区路径详解

吾爱主题 阅读:184 2024-04-01 23:24:37 评论:0

介绍

可以针对分区表的每个分区指定各自的存储路径,对于innodb存储引擎的表只能指定数据路径,因为数据和索引是存储在一个文件当中,对于MYISAM存储引擎可以分别指定数据文件和索引文件,一般也只有RANGE、LIST分区、sub子分区才有可能需要单独指定各个分区的路径,HASH和KEY分区的所有分区的路径都是一样。RANGE分区指定路径和LIST分区是一样的,这里就拿LIST分区来做讲解。

一、MYISAM存储引擎

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 CREATE TABLE th (id INT , adate DATE ) engine= 'MyISAM' PARTITION BY LIST( YEAR (adate)) (    PARTITION p1999 VALUES IN (1995, 1999, 2003)      DATA DIRECTORY = '/data/data'      INDEX DIRECTORY = '/data/idx' ,    PARTITION p2000 VALUES IN (1996, 2000, 2004)      DATA DIRECTORY = '/data/data'      INDEX DIRECTORY = '/data/idx' ,    PARTITION p2001 VALUES IN (1997, 2001, 2005)      DATA DIRECTORY = '/data/data'      INDEX DIRECTORY = '/data/idx' ,    PARTITION p2002 VALUES IN (1998, 2002, 2006)      DATA DIRECTORY = '/data/data'      INDEX DIRECTORY = '/data/idx' );

注意:MYISAM存储引擎的数据文件和索引文件是分库存储所以可以为数据文件和索引文件定义各自的路径,INNODB存储引擎只能定义数据路径。

二、INNODB存储引擎

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 CREATE TABLE thex (id INT , adate DATE ) engine= 'InnoDB' PARTITION BY LIST( YEAR (adate)) (    PARTITION p1999 VALUES IN (1995, 1999, 2003)      DATA DIRECTORY = '/data/data' ,         PARTITION p2000 VALUES IN (1996, 2000, 2004)      DATA DIRECTORY = '/data/data' ,        PARTITION p2001 VALUES IN (1997, 2001, 2005)      DATA DIRECTORY = '/data/data' ,         PARTITION p2002 VALUES IN (1998, 2002, 2006)      DATA DIRECTORY = '/data/data'    );

指定路径之后在原来的路径中innodb生成了4个指向数据存储的路径文件,myisam生成了一个th.par文件指明该表是分区表,同时数据文件和索引文件指向了实际的存储路径。

三、子分区

1.子分区

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 CREATE TABLE tb_sub_dir (id INT , purchased DATE ) ENGINE= 'MYISAM'      PARTITION BY RANGE( YEAR (purchased) )      SUBPARTITION BY HASH( TO_DAYS(purchased) ) (          PARTITION p0 VALUES LESS THAN (1990)          (              SUBPARTITION s0                  DATA DIRECTORY = '/data/data_sub1'                  INDEX DIRECTORY = '/data/idx_sub1' ,              SUBPARTITION s1                  DATA DIRECTORY = '/data/data_sub1'                  INDEX DIRECTORY = '/data/idx_sub1'          ),          PARTITION p1 VALUES LESS THAN (2000)          (              SUBPARTITION s2                  DATA DIRECTORY = '/data/data_sub2'                  INDEX DIRECTORY = '/data/idx_sub2' ,              SUBPARTITION s3                  DATA DIRECTORY = '/data/data_sub2'                  INDEX DIRECTORY = '/data/idx_sub2'          ),          PARTITION p2 VALUES LESS THAN MAXVALUE          (              SUBPARTITION s4                  DATA DIRECTORY = '/data/data_sub3'                  INDEX DIRECTORY = '/data/idx_sub3' ,              SUBPARTITION s5                  DATA DIRECTORY = '/data/data_sub3'                  INDEX DIRECTORY = '/data/idx_sub3'          )      );

2.子分区再分

?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 CREATE TABLE tb_sub_dirnew (id INT , purchased DATE ) ENGINE= 'MYISAM'      PARTITION BY RANGE( YEAR (purchased) )      SUBPARTITION BY HASH( TO_DAYS(purchased) ) (          PARTITION p0 VALUES LESS THAN (1990)          DATA DIRECTORY = '/data/data'          INDEX DIRECTORY = '/data/idx'          (              SUBPARTITION s0                  DATA DIRECTORY = '/data/data_sub1'                  INDEX DIRECTORY = '/data/idx_sub1' ,              SUBPARTITION s1                  DATA DIRECTORY = '/data/data_sub1'                  INDEX DIRECTORY = '/data/idx_sub1'          ),          PARTITION p1 VALUES LESS THAN (2000)          DATA DIRECTORY = '/data/data'          INDEX DIRECTORY = '/data/idx'          (              SUBPARTITION s2                  DATA DIRECTORY = '/data/data_sub2'                  INDEX DIRECTORY = '/data/idx_sub2' ,              SUBPARTITION s3                  DATA DIRECTORY = '/data/data_sub2'                  INDEX DIRECTORY = '/data/idx_sub2'          ),          PARTITION p2 VALUES LESS THAN MAXVALUE          DATA DIRECTORY = '/data/data'          INDEX DIRECTORY = '/data/idx'          (              SUBPARTITION s4                  DATA DIRECTORY = '/data/data_sub3'                  INDEX DIRECTORY = '/data/idx_sub3' ,              SUBPARTITION s5                  DATA DIRECTORY = '/data/data_sub3'                  INDEX DIRECTORY = '/data/idx_sub3'          )      );

也可以给个分区指定路径后再给子分区指定路径,但是这样没有意义,因为数据的存在都是由子分区决定的。

注意:

1.指定的路径必须存在,否则分区无法创建成功

2.MYISAM存储引擎的数据文件和索引文件是分库存储所以可以为数据文件和索引文件定义各自的路径,INNODB存储引擎只能定义数据路径

分区系列文章:

LIST分区:http://www.tuohang.net/article/248216.html

RANGE分区:http://www.tuohang.net/article/248217.html

HASH分区:https://www.tuohang.net/article/248218.html

KEY分区:https://www.tuohang.net/article/248219.html

子分区:https://www.tuohang.net/article/248220.html

指定各分区路径:https://www.tuohang.net/article/248221.html

分区索引以及分区介绍总结:https://www.tuohang.net/article/248222.html

总结

通过给各个分区指定各自的磁盘可以有效的提高读写性能,在条件允许的情况下是一个不错的方法。

到此这篇关于MySQL分区之指定各分区路径的文章就介绍到这了,更多相关MySQL指定各分区路径 内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://www.cnblogs.com/chenmh/p/5644713.html

可以去百度分享获取分享代码输入这里。
声明

1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。

【腾讯云】云服务器产品特惠热卖中
搜索
标签列表
    关注我们

    了解等多精彩内容