首頁 > 軟體

MySQL分割區之指定各分割區路徑詳解

2022-04-14 10:03:59

介紹

可以針對分割區表的每個分割區指定各自的儲存路徑,對於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'
  
);

指定路徑之後在原來的路徑中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'
        )
    );

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

總結

通過給各個分割區指定各自的磁碟可以有效的提高讀寫效能,在條件允許的情況下是一個不錯的方法。

到此這篇關於MySQL分割區之指定各分割區路徑的文章就介紹到這了,更多相關MySQL指定各分割區路徑 內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com