《MYSQL數(shù)據(jù)庫(kù)總結(jié)MySQL的分區(qū)》要點(diǎn):
本文介紹了MYSQL數(shù)據(jù)庫(kù)總結(jié)MySQL的分區(qū),希望對(duì)您有用。如果有疑問(wèn),可以聯(lián)系我們。
前言MYSQL教程
???? 分區(qū)是指根據(jù)一定的規(guī)則將一個(gè)大表分解成多個(gè)更小的部分,這里的規(guī)則一般就是利用分區(qū)規(guī)則將表進(jìn)行水平切分;邏輯上沒(méi)有發(fā)生變化但實(shí)際上表已經(jīng)被拆分成了多個(gè)物理對(duì)象,每個(gè)分成被劃分成了一個(gè)獨(dú)立的對(duì)象.相對(duì)于沒(méi)有分區(qū)的當(dāng)個(gè)表而言分區(qū)的表有很多的優(yōu)勢(shì)包括: 并發(fā)統(tǒng)計(jì)查詢、快速歸檔刪除分區(qū)數(shù)據(jù)、分散存儲(chǔ)、查詢性能更佳.MYSQL教程
mysql5.7以后查詢語(yǔ)句支持指定分區(qū)例如:“ SELECT * FROM t PARTITION (p0,p1) WHERE c < 5
”指定分區(qū)同樣適用DELETE, INSERT, REPLACE, UPDATE, and LOAD DATA, LOAD XML
.MYSQL教程
數(shù)據(jù)庫(kù)版本:mysql5.7.12?MYSQL教程
是否支持分區(qū)MYSQL教程
SHOW PLUGINS ;
MYSQL教程
查詢partition的的狀態(tài)是active就代表支持分區(qū),如果是源碼安裝的話在編譯的過(guò)程中要添加“-DWITH_PARTITION_STORAGE_ENGINE=1 \
”.MYSQL教程
注意: MERGE, CSV, or FEDERATED存儲(chǔ)引擎不支持分區(qū),同一個(gè)表所有的分區(qū)必須使用相同的存儲(chǔ)引擎,不能分區(qū)1使用MYISAM分區(qū)2又使用INNODB;不同的分區(qū)表可以是不同的存儲(chǔ)引擎.MYSQL教程
分區(qū)介紹MYSQL教程
目前mysql可用的分區(qū)類型主要有以下幾種:MYSQL教程
???? RANGE分區(qū):基于一個(gè)給定的連續(xù)區(qū)間范圍,RANGE主要是基于整數(shù)的分區(qū),對(duì)于非整形的字段需要利用表達(dá)式將其轉(zhuǎn)換成整形.MYSQL教程
???? LIST分區(qū):是基于列出的枚舉值列表進(jìn)行分區(qū).MYSQL教程
???? COLUMNS分區(qū):可以無(wú)需通過(guò)表達(dá)式進(jìn)行轉(zhuǎn)換直接對(duì)非整形字段進(jìn)行分區(qū),同時(shí)COLUMNS分區(qū)還支持多個(gè)字段組合分區(qū),只有RANGELIST存在COLUMNS分區(qū),COLUMNS是RANGE和LIST分區(qū)的升級(jí).MYSQL教程
????? HASH分區(qū):基于給定的分區(qū)個(gè)數(shù),將數(shù)據(jù)分配到不同的分區(qū),HASH分區(qū)只能針對(duì)整數(shù)進(jìn)行HASH,對(duì)于非整形的字段只能通過(guò)表達(dá)式將其轉(zhuǎn)換成整數(shù).MYSQL教程
????? KEY分區(qū):支持除text和BLOB之外的所有數(shù)據(jù)類型的分區(qū),key分區(qū)可以直接基于字段做分區(qū)無(wú)需轉(zhuǎn)換成整數(shù).?MYSQL教程
說(shuō)明MYSQL教程
????? 1.注意分區(qū)名的大小寫(xiě)敏感問(wèn)題,和關(guān)鍵字問(wèn)題.MYSQL教程
??????2.無(wú)論哪種分區(qū)類型,要么分區(qū)表中沒(méi)有主鍵或唯一鍵,要么主鍵或唯一鍵包含在分區(qū)列里面,對(duì)于存在主鍵或者唯一鍵的表不能使用主鍵或者唯一鍵之外的字段作為分區(qū)字段.MYSQL教程
????? 3.5.7以前的版本顯示分區(qū)的執(zhí)行計(jì)劃使用:explain PARTITIONS;5.7以后直接執(zhí)行:explainMYSQL教程
????? 4.沒(méi)有強(qiáng)制要求分區(qū)列非空,建議分區(qū)的列為NOT NULL的列;在RANGE 分區(qū)中如果往分區(qū)列中插入NULL值會(huì)被當(dāng)作最小的值來(lái)處理,在LIST分區(qū)中NULL值必須在枚舉列表中否則插入失敗,在HASH/KEY分區(qū)中NULL值會(huì)被當(dāng)作0來(lái)處理.MYSQL教程
??????5.基于時(shí)間類型的字段的轉(zhuǎn)換函數(shù)mysql提供了"YEAR(),MONTH(),DAY(),TO_DAYS(),TO_SECONDS(),WEEKDAY(),DAYOFYEAR()"MYSQL教程
????? 6.拆分合并分區(qū)后會(huì)導(dǎo)致修改的分區(qū)的統(tǒng)計(jì)信息失效,沒(méi)有修改的分區(qū)的統(tǒng)計(jì)信息還在,不影響新插入的值加入到統(tǒng)計(jì)信息;這時(shí)需要對(duì)表執(zhí)行Analyze操作.MYSQL教程
????? 7.針對(duì)非整形字段進(jìn)行RANG\LIST分區(qū)建議使用COLUMNS分區(qū).?MYSQL教程
刪除增加分區(qū)MYSQL教程
在每個(gè)分區(qū)內(nèi)容介紹中詳細(xì)介紹了每種分區(qū)的用法,但是都是介紹在創(chuàng)建表的時(shí)候創(chuàng)建分區(qū)和修改刪除分區(qū)單個(gè),也可以在一張已經(jīng)存在的表中加入分區(qū),可以一次性刪除整個(gè)表的分區(qū).MYSQL教程
1.移除表的分區(qū)MYSQL教程
ALTER TABLE tablename REMOVE PARTITIONING ;
注意:使用remove移除分區(qū)是僅僅移除分區(qū)的定義,并不會(huì)刪除數(shù)據(jù)和drop PARTITION不一樣,后者會(huì)連同數(shù)據(jù)一起刪除MYSQL教程
2.對(duì)已經(jīng)存在記錄的表創(chuàng)建分區(qū),以增加range分區(qū)為例,和創(chuàng)建表建分區(qū)的語(yǔ)法一樣.MYSQL教程
ALTER TABLE `tb_partition`.`tb_varchar` PARTITION BY RANGE(id) PARTITIONS 3( PARTITION part0 VALUES LESS THAN (5000), PARTITION part1 VALUES LESS THAN (10000), PARTITION part2 VALUES LESS THAN (MAXVALUE)) ;
注意:對(duì)已有的表創(chuàng)建分區(qū)之后,數(shù)據(jù)會(huì)依照分區(qū)的定義分布到各個(gè)分區(qū)文件當(dāng)中MYSQL教程
總結(jié)
MYSQL教程
以上就是MySQL的分區(qū)介紹總結(jié)的全部?jī)?nèi)容,希望本文對(duì)大家使用mysql的時(shí)候有所贊助.MYSQL教程
《MYSQL數(shù)據(jù)庫(kù)總結(jié)MySQL的分區(qū)》是否對(duì)您有啟發(fā),歡迎查看更多與《MYSQL數(shù)據(jù)庫(kù)總結(jié)MySQL的分區(qū)》相關(guān)教程,學(xué)精學(xué)透。維易PHP學(xué)院為您提供精彩教程。
轉(zhuǎn)載請(qǐng)注明本頁(yè)網(wǎng)址:
http://www.snjht.com/jiaocheng/12874.html