您好,登錄后才能下訂單哦!
草稿丟失,發(fā)表得不完整,稍后重新整理
mysql表分區(qū)技術(shù)能有效解決水平拆分和垂直拆分的不足,可操作性和效率都更優(yōu)。以下是一些實驗總結(jié)。
InnoDB引擎需先在配置文件中設(shè)置: innodb_file_per_table=1
--innodb : 主表.frm 保存表結(jié)構(gòu)和分區(qū)數(shù)目一致的 .ibd 文件,用于保存數(shù)據(jù)和索引。
--myisam:主表.frm保存表結(jié)構(gòu)定義,主表.par保存分區(qū)信息, 和分區(qū)數(shù)目一致的 .MYD文件,用于保存數(shù)據(jù),.MDI文件用于索引。
range分區(qū):
CREATE TABLE a(
id INT PRIMARY KEY AUTO_INCREMENT,
NAME CHAR(20))ENGINE=INNODB CHARSET=utf8
PARTITION BY RANGE(id)(
PARTITION p1 VALUES LESS THAN (100),
PARTITION p2 VALUES LESS THAN (200),
PARTITION p3 VALUES LESS THAN (300),
PARTITION p4 VALUES LESS THAN MAXVALUE);
----------建立一個以id 區(qū)間來劃分的分別,當id 小于100時數(shù)據(jù)保存到p1分區(qū),100到199時保存到p2分區(qū),200到299時保存到p3分區(qū),大于300時保存到p4分區(qū);
[root@master test]#dir
a.frm a#P#p1.ibd a#P#p2.ibd a#P#p4.ibd db.opt
List分區(qū):
CREATE TABLE bc(
id INT NOT NULL AUTO_INCREMENT,
par_no INT NOT NULL DEFAULT '1',
a_name CHAR(20) NOT NULL,
PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY LIST(par_no)(
PARTITION p0 VALUES IN (10,20,30),
PARTITION p1 VALUES IN (40,50,60),
PARTITION p2 VALUES IN (70,80,100));
---插入數(shù)據(jù)時,par_no的值必須在分區(qū)定義中存在,否則不能插入并報錯。
[root@master test]# dir nb*
nb.frmnb.parnb#P#p0.MYD nb#P#p0.MYI nb#P#p1.MYD nb#P#p1.MYI nb#P#p2.MYD nb#P#p2.MYI nb#P#p3.MYD nb#P#p3.MYInb#P#p4.MYD nb#P#p4.MYI
提示警告:意思大概mysql分區(qū)以后的版本不支持myisam引擎吧,換成innodb就可以了。
Warning Code : 1287
The partition engine, used by table 'test.bc', is deprecated and will be removed in a future release. Please use native partitioning instead.
Hash分區(qū):
CREATE TABLE nb(
id INT NOT NULL AUTO_INCREMENT,
par_no INT NOT NULL DEFAULT '1',
a_name CHAR(20) NOT NULL,
PRIMARY KEY(id,par_no)) ENGINE=MYISAM CHARSET=gbk PARTITION BY HASH(id)
PARTITIONS 5; --partition 多了個s ,讓mysql自動id的Hash 值存儲到5個分區(qū)里。
查詢分區(qū)表中存在的數(shù)據(jù)量:
SELECT PARTITION_NAME,PARTITION_METHOD,PARTITION_EXPRESSION,PARTITION_DESCRIPTION,TABLE_ROWS,SUBPARTITION_NAME,SUBPARTITION_METHOD,SUBPARTITION_EXPRESSION
FROM information_schema.PARTITIONS WHERE TABLE_SCHEMA=SCHEMA() AND TABLE_NAME='bcd'
分區(qū)管理--測試總結(jié): 刪除分區(qū): ALTER TABLE tablename REMOVE PARTITIONING ; -- 刪除分區(qū)定義,所有數(shù)據(jù)集中到一個表,數(shù)據(jù)不丟失 ALTER TABLE bc DROP PARTITION p1; --刪除分區(qū)的同時會刪除分區(qū)中的數(shù)據(jù) 修改分區(qū): ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2; --Hash分區(qū)重新定義為兩個,并會重新分配數(shù)據(jù) 合并分區(qū) ALTER TABLE bc REORGANIZE PARTITION p1,p0 INTO ( PARTITION p6 VALUES IN (10,20,30,40)); --將BC表中的p0,p1分區(qū)合并到p6分區(qū),并且p0,p1的[list]值必須包含在新的分區(qū)內(nèi),否則不在新區(qū)[list]中的數(shù)據(jù)會丟失; ALTER TABLE a REORGANIZE PARTITION p0,p1,p2 INTO (PARTITION p0 VALUES LESS THAN (500),PARTITION p1 VALUES LESS THAN maxvalue); --重定義分區(qū)結(jié)構(gòu):將Range分區(qū)p1,p2合并到p0分區(qū),由于原p2分區(qū)是maxvalue值,所以還得同時增加一個新的maxvalue分區(qū),否則報錯。 拆分分區(qū): 添加分區(qū): 未有分區(qū)的情況下: ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2; --用id 列給表分兩個hash分區(qū);如果有unique鍵,要先刪除. ALTER TABLE a PARTITION BY RANGE(id)( --a 表無分區(qū). PARTITION p0 VALUES LESS THAN (1000), PARTITION p1 VALUES LESS THAN (2000), PARTITION p2 VALUES LESS THAN maxvalue) -------------------------------------------------------------------- ALTER TABLE bc PARTITION BY LIST(par_no) (PARTITION p1 ----為未定義分區(qū)表的BC表添加兩個list分區(qū); VALUES IN (10,20,30),PARTITION p2 VALUES IN (40,50,60,70,80)); 已有分區(qū)的情況下: 合并分區(qū): ALTER TABLE abc REORGANIZE PARTITION p2 INTO ( PARTITION p2 VALUES LESS THAN (6000),PARTITION p3 VALUES LESS THAN maxvalue); --重新定義Range分區(qū)p2,并新加一個p3分區(qū),p2分區(qū)的值不能小于現(xiàn)有的最大值,且須新境一個包含最大值(Maxvalue)的新分區(qū),否則報錯 ALTER TABLE bc ADD PARTITION (PARTITION p3 VALUES IN (20,30));--添加一個list分區(qū) ALTER TABLE nb ADD PARTITION PARTITIONS 2; --(Hash分區(qū)),新加后現(xiàn)有分區(qū)里的數(shù)據(jù)會平滑分攤到新分區(qū),myisam引擎在上面的查詢語句中可以體現(xiàn)出來,innodb引擎則計數(shù)信息丟失,從0開始重新計數(shù),但表中數(shù)據(jù)變不會丟失.
注意:刪除分區(qū)同時會將分區(qū)中的數(shù)據(jù)刪除,同時枚舉的list值也被刪除,后面無法往表中插入該值的數(shù)據(jù)。
免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。