欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL數(shù)據(jù)庫表的合并及分區(qū)方式

 更新時間:2023年08月11日 14:36:09   作者:PHP經(jīng)驗分享  
這篇文章主要介紹了MySQL數(shù)據(jù)庫表的合并及分區(qū)方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

MySQL數(shù)據(jù)庫表的合并及分區(qū)

我們來聊聊處理大數(shù)據(jù)時Mysql的存儲優(yōu)化。當(dāng)數(shù)據(jù)達到一定量時,一般的存儲方式就無法解決高并發(fā)問題了。

最直接的MySQL優(yōu)化就是分區(qū)分表,以下是我個人對分區(qū)分表的筆記:

1.合并表

把多個結(jié)果相同的的表合并為一個容器。

  • 容器的類型:Myisam,存儲引擎:merge
  • 存在的問題:有重復(fù)的行
create table packtable(
? id ....
)engine=merge unique=(table1,table2);

2.表的分區(qū)

2.1,水平分區(qū):根據(jù)某個字段進行分區(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ū):第一選擇基于某 列的值是否屬于某個 集合

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ù)月份進行分區(qū)儲存,一共分12個區(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字段進行分區(qū)儲存,一共分5個區(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ū):可以計算一列或者多列進行分區(qū)

--
-- 根據(jù)branch_id字段進行分區(qū)儲存,一共分5個區(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ù)的歸屬,典型的就是按照時間維度的月份分區(qū)
ALTER TABLE `table_name` ADD PARTITION(PARTITION p20190107 VALUES LESS THAN (20190107) ENGINE = InnoDB);
-- List分區(qū),分區(qū)字段必須是整型或者轉(zhuǎn)換為整型
-- 按照某個字段上的規(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é)

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Ubuntu系統(tǒng)安裝mysql超詳細步驟

    Ubuntu系統(tǒng)安裝mysql超詳細步驟

    這篇文章主要給大家介紹了關(guān)于Ubuntu系統(tǒng)安裝mysql的相關(guān)資料,現(xiàn)在的軟件越來越好安裝,尤其是在ubuntu下安裝軟件,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-09-09
  • MySQL中的多表查詢與事務(wù)操作

    MySQL中的多表查詢與事務(wù)操作

    這篇文章主要介紹了MySQL中的多表查詢與事務(wù)操作,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Ubuntu安裝Mysql啟用遠程連接的詳細圖文教程

    Ubuntu安裝Mysql啟用遠程連接的詳細圖文教程

    在Ubuntu系統(tǒng)中添加了MySQL賬戶,賦予了數(shù)據(jù)庫完全操作權(quán)限,并且允許數(shù)據(jù)庫從外部鏈接但是,還是無法遠程訪問MySQL數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于Ubuntu安裝Mysql啟用遠程連接的相關(guān)資料,需要的朋友可以參考下
    2023-04-04
  • C++連接使用MySQL的方法

    C++連接使用MySQL的方法

    這篇文章主要為大家詳細介紹了C++連接使用MySQL的方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-07-07
  • mysql 觸發(fā)器語法與應(yīng)用示例

    mysql 觸發(fā)器語法與應(yīng)用示例

    這篇文章主要介紹了mysql 觸發(fā)器語法與應(yīng)用,結(jié)合實例形式詳細分析了mysql 觸發(fā)器的基本語法與插入、更細、刪除等相關(guān)操作技巧,需要的朋友可以參考下
    2020-05-05
  • MySQL8.0新特性之不可見主鍵的使用

    MySQL8.0新特性之不可見主鍵的使用

    MySQL8.0.30版本引入不可見主鍵,它可以自動為沒有顯式指定主鍵的?InnoDB?表創(chuàng)建一個不可見的主鍵,本文主要介紹了MySQL8.0新特性之不可見主鍵的使用,具有一定的參考價值,感興趣的可以了解一下
    2024-04-04
  • MySQL 查詢某個字段不重復(fù)的所有記錄

    MySQL 查詢某個字段不重復(fù)的所有記錄

    現(xiàn)在想從這5條記錄中查詢所有title不重復(fù)的記錄
    2009-05-05
  • MySQL表類型 存儲引擎 的選擇

    MySQL表類型 存儲引擎 的選擇

    這篇文章主要介紹了MySQL表類型存儲引擎的選擇,文章圍繞MySQL表類型存儲引擎的選擇的相關(guān)資料展開內(nèi)容,需要的朋友可以參考一下,希望對你有所幫助
    2021-11-11
  • MySQL MHA 運行狀態(tài)監(jiān)控介紹

    MySQL MHA 運行狀態(tài)監(jiān)控介紹

    這篇文章主要介紹MySQL MHA 運行狀態(tài)監(jiān)控,MHA(Master HA)是一款開源的 MySQL 的高可用程序,它為 MySQL 主從復(fù)制架構(gòu)提供了 automating master failover 功能,想具體了解的小伙伴可以和小編一起學(xué)習(xí)下面文章內(nèi)容
    2021-10-10
  • 詳解MySQL客戶端/服務(wù)器運行架構(gòu)

    詳解MySQL客戶端/服務(wù)器運行架構(gòu)

    這篇文章主要介紹了詳解MySQL客戶端/服務(wù)器運行架構(gòu),文章圍繞主題展開詳細的內(nèi)容介紹,具有一定的參考價值,需要的小伙伴可以參考一下
    2022-09-09

最新評論