MySQL數(shù)據(jù)庫(kù)表的合并及分區(qū)方式
MySQL數(shù)據(jù)庫(kù)表的合并及分區(qū)
我們來聊聊處理大數(shù)據(jù)時(shí)Mysql的存儲(chǔ)優(yōu)化。當(dāng)數(shù)據(jù)達(dá)到一定量時(shí),一般的存儲(chǔ)方式就無法解決高并發(fā)問題了。
最直接的MySQL優(yōu)化就是分區(qū)分表,以下是我個(gè)人對(duì)分區(qū)分表的筆記:
1.合并表
把多個(gè)結(jié)果相同的的表合并為一個(gè)容器。
- 容器的類型:Myisam,存儲(chǔ)引擎:merge
- 存在的問題:有重復(fù)的行
create table packtable( ? id .... )engine=merge unique=(table1,table2);
2.表的分區(qū)
2.1,水平分區(qū):根據(jù)某個(gè)字段進(jìn)行分區(qū)(RANGE分區(qū))
create table test1( id int(10) primary key auto_increment, ?score int(3) )engine=innodb default charset=utf8 partition by range(score)( //根據(jù)score字段分區(qū),score小于60的在p1分區(qū) ? partition p1 values less than(60), //根據(jù)score字段分區(qū),score小于70的在p2 分區(qū) ?partition p2 values less than(70), ?//根據(jù)score字段分區(qū),score大于70的在p3 分區(qū) ? partition p3 values lessthan maxvalue ?);
2.2 list分區(qū):第一選擇基于某 列的值是否屬于某個(gè) 集合
create table test1( ? ? ?id int(10) primary key auto_increment, ? ? ?branch_id int(3) )engine=innodb default charset=utf8 partition by list(branch_id ?)( ? ? //根據(jù)branch_id 字段分區(qū),branch_id ?在1,2,3之中的為p1分區(qū) ? ? ?partition p1 values less in(1,2,3), ? ? //根據(jù)branch_id 字段分區(qū),branch_id ?在7,8,9 之中的為p2分區(qū) ? ? ?partition p2 values less in(7,8,9) );
2.3 hash分區(qū):支持?jǐn)?shù)值類型
-- -- 根據(jù)birthda字段獲取月份,再根據(jù)月份進(jìn)行分區(qū)儲(chǔ)存,一共分12個(gè)區(qū); -- create table test1( ?id int(10) primary key auto_increment, ?birthday date )engine=innodb default charset=utf8 partition by hash(month(birthday)) ?partitions 12;?
2.4 線性分區(qū)(linear hash):大數(shù)據(jù)是增加,合并,拆分速度更快
-- -- 根據(jù)branch_id字段進(jìn)行分區(qū)儲(chǔ)存,一共分5個(gè)區(qū); -- create table test1( ?id int(10) primary key auto_increment, ?branch_id int(3) )engine=innodb default charset=utf8 partition by linear hash (branch_id ?) partitions 5;
2.5 key分區(qū):可以計(jì)算一列或者多列進(jìn)行分區(qū)
-- -- 根據(jù)branch_id字段進(jìn)行分區(qū)儲(chǔ)存,一共分5個(gè)區(qū); -- create table test1( ?id int(10) primary key auto_increment, ?branch_id int(3) )engine=innodb default charset=utf8 partition by key (branch_id ?) partitions 5;
Mysql新增分區(qū),刪除分區(qū),合并分區(qū)
-- range分區(qū),分區(qū)字段必須是整型或者轉(zhuǎn)換為整型 -- 按照字段的區(qū)間劃分?jǐn)?shù)據(jù)的歸屬,典型的就是按照時(shí)間維度的月份分區(qū) ALTER TABLE `table_name` ADD PARTITION(PARTITION p20190107 VALUES LESS THAN (20190107) ENGINE = InnoDB); -- List分區(qū),分區(qū)字段必須是整型或者轉(zhuǎn)換為整型 -- 按照某個(gè)字段上的規(guī)則,不同的數(shù)據(jù)離散地分布在不同的區(qū)中 ALTER TABLE `table_name` ADD PARTITION(PARTITION p20190107 VALUES IN (20190107) ENGINE = InnoDB); -- 刪除分區(qū) ALTER TABLE `table_name` DROP PARTITION p20190107; -- 合并分區(qū) ALTER TABLE `table_name` REORGANIZE PARTITION p1,p2 INTO (PARTITION p4 VALUES less than (20190105) );
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Ubuntu系統(tǒng)安裝mysql超詳細(xì)步驟
這篇文章主要給大家介紹了關(guān)于Ubuntu系統(tǒng)安裝mysql的相關(guān)資料,現(xiàn)在的軟件越來越好安裝,尤其是在ubuntu下安裝軟件,文中通過圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-09-09Ubuntu安裝Mysql啟用遠(yuǎn)程連接的詳細(xì)圖文教程
在Ubuntu系統(tǒng)中添加了MySQL賬戶,賦予了數(shù)據(jù)庫(kù)完全操作權(quán)限,并且允許數(shù)據(jù)庫(kù)從外部鏈接但是,還是無法遠(yuǎn)程訪問MySQL數(shù)據(jù)庫(kù),下面這篇文章主要給大家介紹了關(guān)于Ubuntu安裝Mysql啟用遠(yuǎn)程連接的相關(guān)資料,需要的朋友可以參考下2023-04-04MySQL MHA 運(yùn)行狀態(tài)監(jiān)控介紹
這篇文章主要介紹MySQL MHA 運(yùn)行狀態(tài)監(jiān)控,MHA(Master HA)是一款開源的 MySQL 的高可用程序,它為 MySQL 主從復(fù)制架構(gòu)提供了 automating master failover 功能,想具體了解的小伙伴可以和小編一起學(xué)習(xí)下面文章內(nèi)容2021-10-10詳解MySQL客戶端/服務(wù)器運(yùn)行架構(gòu)
這篇文章主要介紹了詳解MySQL客戶端/服務(wù)器運(yùn)行架構(gòu),文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-09-09