真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

mysql表分區(qū)實(shí)驗(yàn)總結(jié)

草稿丟失,發(fā)表得不完整,稍后重新整理

創(chuàng)新互聯(lián)建站專注于疊彩網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗(yàn)。 熱誠(chéng)為您提供疊彩營(yíng)銷型網(wǎng)站建設(shè),疊彩網(wǎng)站制作、疊彩網(wǎng)頁(yè)設(shè)計(jì)、疊彩網(wǎng)站官網(wǎng)定制、小程序開(kāi)發(fā)服務(wù),打造疊彩網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供疊彩網(wǎng)站排名全網(wǎng)營(yíng)銷落地服務(wù)。

MySQL表分區(qū)技術(shù)能有效解決水平拆分和垂直拆分的不足,可操作性和效率都更優(yōu)。以下是一些實(shí)驗(yàn)總結(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);


 ----------建立一個(gè)以id 區(qū)間來(lái)劃分的分別,當(dāng)id 小于100時(shí)數(shù)據(jù)保存到p1分區(qū),100到199時(shí)保存到p2分區(qū),200到299時(shí)保存到p3分區(qū),大于300時(shí)保存到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ù)時(shí),par_no的值必須在分區(qū)定義中存在,否則不能插入并報(bào)錯(cuò)。

[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 多了個(gè)s ,讓mysql自動(dòng)id的Hash 值存儲(chǔ)到5個(gè)分區(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'

mysql表分區(qū)實(shí)驗(yàn)總結(jié)

分區(qū)管理--測(cè)試總結(jié):

刪除分區(qū):
ALTER TABLE tablename REMOVE PARTITIONING ; --  刪除分區(qū)定義,所有數(shù)據(jù)集中到一個(gè)表,數(shù)據(jù)不丟失
ALTER TABLE bc DROP PARTITION p1;           --刪除分區(qū)的同時(shí)會(huì)刪除分區(qū)中的數(shù)據(jù)

修改分區(qū):
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2;  --Hash分區(qū)重新定義為兩個(gè),并會(huì)重新分配數(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ù)會(huì)丟失;

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值,所以還得同時(shí)增加一個(gè)新的maxvalue分區(qū),否則報(bào)錯(cuò)。

拆分分區(qū):



添加分區(qū):

未有分區(qū)的情況下:
ALTER TABLE nb PARTITION BY HASH(id) PARTITIONS 2; --用id 列給表分兩個(gè)hash分區(qū);如果有unique鍵,要先刪除.

ALTER TABLE a  PARTITION BY RANGE(id)(            --a 表無(wú)分區(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表添加兩個(gè)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,并新加一個(gè)p3分區(qū),p2分區(qū)的值不能小于現(xiàn)有的最大值,且須新境一個(gè)包含最大值(Maxvalue)的新分區(qū),否則報(bào)錯(cuò)

ALTER TABLE bc  ADD PARTITION  (PARTITION p3 VALUES IN (20,30));--添加一個(gè)list分區(qū)

ALTER TABLE nb ADD PARTITION PARTITIONS 2;  --(Hash分區(qū)),新加后現(xiàn)有分區(qū)里的數(shù)據(jù)會(huì)平滑分?jǐn)偟叫路謪^(qū),myisam引擎在上面的查詢語(yǔ)句中可以體現(xiàn)出來(lái),innodb引擎則計(jì)數(shù)信息丟失,從0開(kāi)始重新計(jì)數(shù),但表中數(shù)據(jù)變不會(huì)丟失.

注意:刪除分區(qū)同時(shí)會(huì)將分區(qū)中的數(shù)據(jù)刪除,同時(shí)枚舉的list值也被刪除,后面無(wú)法往表中插入該值的數(shù)據(jù)。


分享名稱:mysql表分區(qū)實(shí)驗(yàn)總結(jié)
瀏覽地址:http://weahome.cn/article/psoghi.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部