讀mysql幫助手冊后的一點總結
概述
分區允許以一個任意的大小,跨系統、跨磁盤的將一個表分為多個部分。實際上,表的不同部分在不同的位置被存儲為單獨的表。用戶所選擇的、實現數據分割的規則被稱為分區函數,這在MySQL中它可以是模數,或者是簡單的匹配一個連續的數值區間或數值列表,或者是一個內部HASH函數,或一個線性HASH函數。
partition的一些優點包括:
- myisam支持將表的多個部分存儲於不同的文件系統或是磁盤,可以存儲更多數據
- 提供直接刪除一個partition的語句,速度較快
- 通過partitioning-pruning優化某些查詢語句
partition 的局限:
- innodb不支持directory選擇,partition后的表不能存儲於多個路徑中
- 目前的mysql版本(截止到mysql5.5)中還沒有對partition進行並行優化(如 sum() count() max()等)
- 目前的mysql版本中還不支持多磁盤的並行IO
partition類型
- RANGE分區
CREATE TABLE employees (id INT NOT NULL,fname VARCHAR(30),lname VARCHAR(30),hired DATE NOT NULL DEFAULT '1970-01-01',separated DATE NOT NULL DEFAULT '9999-12-31',job_code INT,store_id INT)PARTITION BY RANGE (YEAR(separated)) (PARTITION p0 VALUES LESS THAN (1991),PARTITION p1 VALUES LESS THAN (1996),PARTITION p2 VALUES LESS THAN (2001),PARTITION p3 VALUES LESS THAN MAXVALUE);
- LIST分區
CREATE TABLE employees (id INT NOT NULL,fname VARCHAR(30),lname VARCHAR(30),hired DATE NOT NULL DEFAULT '1970-01-01',separated DATE NOT NULL DEFAULT '9999-12-31',job_code INT,store_id INT)PARTITION BY LIST(store_id)PARTITION pNorth VALUES IN (3,5,6,9,17),PARTITION pEast VALUES IN (1,2,10,11,19,20),PARTITION pWest VALUES IN (4,12,13,14,18),PARTITION pCentral VALUES IN (7,8,15,16));
- HASH分區
CREATE TABLE employees (id INT NOT NULL,fname VARCHAR(30),lname VARCHAR(30),hired DATE NOT NULL DEFAULT '1970-01-01',separated DATE NOT NULL DEFAULT '9999-12-31',job_code INT,store_id INT)PARTITION BY HASH(store_id)PARTITIONS 4;
- LINENEAR HASH
CREATE TABLE employees (id INT NOT NULL,fname VARCHAR(30),lname VARCHAR(30),hired DATE NOT NULL DEFAULT '1970-01-01',separated DATE NOT NULL DEFAULT '9999-12-31',job_code INT,store_id INT)PARTITION BY LINEAR HASH(YEAR(hired))PARTITIONS 4;
- KEY分區
CREATE TABLE tk (col1 INT NOT NULL,col2 CHAR(5),col3 DATE)PARTITION BY LINEAR KEY (col1)PARTITIONS 3;
- 子分區
CREATE TABLE ts (id INT, purchased DATE)PARTITION BY RANGE(YEAR(purchased))SUBPARTITION BY HASH(TO_DAYS(purchased))SUBPARTITIONS 2(PARTITION p0 VALUES LESS THAN (1990),PARTITION p1 VALUES LESS THAN (2000),PARTITION p2 VALUES LESS THAN MAXVALUE);
分區修剪(Partition Pruning)
分區修剪是MySQL5.1.6版本后實現的,其原理很簡單,一句話來描述就是“不要掃描那些沒有匹配值的分區”。
