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

作者:pursuer.chen 时间:2024-01-15 00:48:00 

介绍

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

一、MYISAM存储引擎

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存储引擎

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'

);

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

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

三、子分区

1.子分区

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'
       )
   );

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

2.子分区再分

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存储引擎只能定义数据路径

分区系列文章:

RANGE分区:https://www.jb51.net/article/244269.htm

COLUMN分区:https://www.jb51.net/article/96515.htm

LIST分区:https://www.jb51.net/article/244256.htm

HASH分区:https://www.jb51.net/article/244277.htm

KEY分区:https://www.jb51.net/article/244282.htm

子分区:https://www.jb51.net/article/244294.htm

指定各分区路径:https://www.jb51.net/article/244296.htm

分区索引以及分区介绍总结:https://www.jb51.net/article/244300.htm

来源:https://www.cnblogs.com/chenmh/p/5644713.html

标签:mysql,分区,路径
0
投稿

猜你喜欢

  • Golang模拟令牌桶进行对访问的限流方式

    2024-04-26 17:34:25
  • 在TensorFlow中屏蔽warning的方式

    2023-05-08 10:54:19
  • MySQL实现字段或字符串拼接的三种方式总结

    2024-01-22 04:23:47
  • js几个不错的函数 $$()

    2024-04-29 13:41:11
  • Python实现将xml导入至excel

    2023-10-01 06:17:45
  • Git常用场景使用之分支操作

    2022-01-06 02:10:56
  • Python深度学习pytorch神经网络Dropout应用详解解

    2023-01-02 11:18:54
  • 详解Go语言RESTful JSON API创建

    2024-04-26 17:34:17
  • MySQL之xtrabackup备份恢复的实现

    2024-01-15 06:59:08
  • python环境中的概念conda中与环境相关指令操作

    2021-01-09 19:40:55
  • 关于CSS中字号控制的兼容性研究[译]

    2009-02-24 16:35:00
  • tensorflow多维张量计算实例

    2022-02-05 00:43:48
  • 详解利用Pandas求解两个DataFrame的差集,交集,并集

    2023-10-21 06:14:51
  • Go 语言数组和切片的区别详解

    2024-04-25 15:08:37
  • Python使用cx_Oracle调用Oracle存储过程的方法示例

    2021-01-26 19:37:28
  • seaborn绘制双变量联合分布图示例详解

    2021-04-29 01:49:24
  • Vue登录拦截 登录后继续跳转指定页面的操作

    2024-05-28 15:48:14
  • javascript函数定义的几种区别小结

    2024-04-10 10:40:03
  • json 转 mot17数据格式的实现代码 (亲测有效)

    2022-03-06 09:23:53
  • Golang依赖注入工具digo的使用详解

    2023-08-27 13:00:43
  • asp之家 网络编程 m.aspxhome.com