Mysql基礎教程 mysql進階

Mysql表的list分區



list分區


類似于按RANGE分區,區別在于LIST分區是基于列值匹配一個離散值集合中的某個值來進行選擇。它主要針對離散的值。LIST分區通過使用“PARTITION BY LIST(expr)”來實現,其中“expr”是某列值或一個基于某個列值、并返回一個整數值的表達式,然后通過“VALUES IN (value_list)”的方式來定義每個分區,其中“value_list”是一個通過逗號分隔的整數列表。 注釋:在MySQL 5.1中,當使用LIST分區時,有可能只能匹配整數列表。


Sql代碼


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


假定有20個音像店,分布在4個有經銷權的地區,如下表所示:


====================


地區      商店ID 號


北區      3, 5, 6, 9, 17


東區      1, 2, 10, 11, 19, 20


西區      4, 12, 13, 14, 18


中心區   7, 8, 15, 16


====================


要按照屬于同一個地區商店的行保存在同一個分區中的方式來分割表,可以使用下面的“CREATE TABLE”語句:


Sql代碼


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


這使得在表中增加或刪除指定地區的雇員記錄變得容易起來。例如,假定西區的所有音像店都賣給了其他公司。那么與在西區音像店工作雇員相關的所有記錄(行)可以使用查詢“ALTER TABLE employees DROP PARTITION pWest;”來進行刪除,它與具有同樣作用的DELETE(刪除)查詢“DELETE query DELETE FROM employees WHERE store_id IN (4,12,13,14,18);”比起來,要有效得多。【要點】:如果試圖插入列值(或分區表達式的返回值)不在分區值列表中的一行時,那么“INSERT”查詢將失敗并報錯。例如,假定LIST分區的采用上面的方案,下面的查詢將失敗:


Sql代碼


INSERT INTO employees VALUES(224, 'Linus', 'Torvalds', '2002-05-01', '2004-10-12', 42, 21);


這是因為“store_id”列值21不能在用于定義分區pNorth, pEast, pWest,或pCentral的值列表中找到。要重點注意的是,LIST分區沒有類似如“VALUES LESS THAN MAXVALUE”這樣的包含其他值在內的定義。將要匹配的任何值都必須在值列表中找到。LIST分區除了能和RANGE分區結合起來生成一個復合的子分區,與HASH和KEY分區結合起來生成復合的子分區也是可能的。


示例


進入服務器。


0.png


查看數據庫。


1.png


使用數據庫。


2.png


創建list分區。


3.png


插入這條語句。


4.png


插入一個值它不在分區的這個枚舉值里面,插入出錯。


5.png


對于mysql5.5以后,支持的是一個非int類型的list分區。


創建一張表。


6.png


插入數據,這樣已經插入到數據當中。


7.png


插入soft。


8.png


插入ho,由于插入的值不在這個分區里面,它會報錯,因為我們創建的時候有兩個分區,這兩個分區的兩個值一個是hr,一個是soft。


9.png



Hash分區


基于用戶定義的表達式的返回值來進行選擇的分區,該表達式使用將要插入到表中的這些行的列值進行計算。這個函數可以包含MySQL 中有效的、產生非負整數值的任何表達式。


要使用HASH分區來分割一個表,要在CREATE TABLE 語句上添加一個“PARTITION BY HASH (expr)”子句,其中“expr”是一個返回一個整數的表達式。它可以僅僅是字段類型為MySQL整型的一列的名字。此外,你很可能需要在后面再添加一個“PARTITIONS num”子句,其中num是一個非負的整數,它表示表將要被分割成分區的數量。


Sql代碼


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)   //根據計算機計算的hash,它所計算的hash是根據store_id這個hash   //根據hash的計算,它會把它分成4個區,執行這個的話,它會默認你在一個文件當中
PARTITIONS 4;


如果沒有包括一個PARTITIONS子句,那么分區的數量將默認為1。例外:對于NDB Cluster(簇)表,默認的分區數量將與簇數據節點的數量相同,這種修正可能是考慮任何MAX_ROWS設置,以便確保所有的行都能合適地插入到分區中。


示例


創建hash分區。


92.png



Keys分區


類似于按HASH分區,區別在于KEY分區只支持計算一列或多列,且MySQL服務器提供其自身的哈希函數。必須有一列或多列包含整數值。


Sql代碼


CREATE TABLE tk (
    col1 INT NOT NULL,
    col2 CHAR(5),
    col3 DATE
)
PARTITION BY LINEAR KEY (col1)
PARTITIONS 3;


在KEY分區中使用關鍵字LINEAR和在HASH分區中使用具有同樣的作用,分區的編號是通過2的冪(powers-of-two)算法得到,而不是通過模數算法。


示例


Keys分區中,這個列可以是一列,也可以是多列,如果沒有寫PARTITIONS,會認為是一個分區,如果寫了PARTITIONS,那么這里面你寫多少個就會有多少個分區。


93.png



分區的管理


分區的刪除


如果刪除了分區,那么分區下面的數據也必然會被刪除掉。刪除分區的語法。


alter table 表名
drop partition 分區名


為一個Range或者List分區的表增加一個分區,它的語法如下:


alter table 表名 add partition(partition 分區名字 values less than (某個具體的值)


示例


查看之前的分區。


94.png


查看employees這張表。


95.png


刪除這個分區。


96.png


如果我們把剛才的分區刪掉,那么鎖定的數據也會被刪掉,現在這個數據已經沒有了,是因為我們把這個分區刪掉了,刪掉之后它同樣的會把分區里面的數據刪掉。


97.png


將剛才刪掉的分區添加上來,分區的管理我們可以刪除一個分區,或者增加一個分區。


98.png



【本文由麥子學院獨家原創,轉載請注明出處并保留原文鏈接】 

logo
? 2012-2016 www.jvbprd.live
蜀ICP備13014270號-4 Version 5.0.0 release20160127

免費領取價值1888元求職寶典!

客服熱線 400-862-8862

回到頂部

彩票安徽25选5