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

MySQL分表和分區(qū)的具體實現方法

 更新時間:2019年06月28日 16:05:51   作者:FOOFISH-PYTHON之禪  
這篇文章主要介紹了MySQL分表和分區(qū)的具體實現方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下

垂直分表

垂直分表就是一個包含有很多列的表拆分成多個表,比如表A包含20個字段,現在拆分成表A1和A2,兩個表各十個字段(具體如何拆根據業(yè)務來選擇)。

優(yōu)勢:在高并發(fā)的情境下,可以減少表鎖和行鎖的次數。

劣勢:在數據記錄非常大的情況下,讀寫速度還是會遇到瓶頸。

水平分表

假如某個網站,它的數據庫的某個表已經達到了上億條記錄,那么此時如果通過select去查詢,在沒有索引的情況下,他的查詢會非常慢,那么就可以通過hash算法將這個表分成10個子表(此時每個表的 的數據量只有1000萬條了)。

同時生成一個總表,記錄各個子表的信息,假如查詢一條id=100的記錄,它不再需要全表掃描,而是通過總表找到該記錄在哪個對應的子表上,然后再去相應的表做檢索,這樣就降低了IO壓力。

劣勢:會給前端程序應用程序的SQL代碼的維護帶來很大的麻煩,這時候可以使用MySQL的Merge存儲引擎實現分表。

---------------------------------------我是蛋疼的分割線----------------------------------------------------

用Merge存儲引擎分表,對應用程序的SQL語句來說是透明的,不需要修改任何代碼。

CREATE TABLE t1 ( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY, message CHAR(20));
CREATE TABLE t2 ( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY, message CHAR(20));
INSERT INTO t1 (message) VALUES ('Testing'),('table'),('t1');
INSERT INTO t2 (message) VALUES ('Testing'),('table'),('t2');
CREATE TABLE total (a INT NOT NULL AUTO_INCREMENT PRIMARY KEY, message CHAR(20)) ENGINE=MERGE UNION=(t1,t2) INSERT_METHOD=LAST;

在創(chuàng)建total表的時候可能報錯:

Unable to open underlying table which is differently defined or of non-MyISAM type or doesn't exist

實際上merge存儲引擎是一個虛擬的表,對應的實際表必須是myisam類型的表,如果你的mysql是5.1以上版本,默認數據庫使用的事InnoDB存儲引擎的,所以在創(chuàng)建total時,t1和t2表必須是myisam存儲引擎的。

如果需要定期增加分表,只需要修改merge表的union即可。

CREATE TABLE t3( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY, message CHAR(20));
ALTER TABLE total UNION=(t1,t2,t3)

橫向分區(qū)

舉例說明:假如有100W條數據,分成十份,前10W條數據放到第一個分區(qū),第二個10W條數據放到第二個分區(qū),依此類推。取出一條數據的時候,這條數據包含了表結構中的所有字段,橫向分區(qū)并沒有改變表的結構。

縱向分區(qū)

舉例說明:在設計用戶表的時候,開始的時候沒有考慮好,而把個人的所有信息都放到了一張表里面去,這個表里面就會有比較大的字段,如個人簡介,而這些簡介呢,也許不會有好多人去看,所以等到有人要看的時候,再去查找,分表的時候,可以把這樣的大字段,分開來

完整的一張表,都對應三個文件,一個.MYD數據文件,.MYI索引文件,.frm表結構文件。

相關文章

  • 在CMD中操作mysql數據庫出現中文亂碼解決方案

    在CMD中操作mysql數據庫出現中文亂碼解決方案

    有說將cmd字符編碼用chcp命令改為65001(utf8字符編碼),可這樣之后根本無法輸入中文,查詢出的中問結果依舊亂碼 。下面小編給大家?guī)砹嗽贑MD中操作mysql數據庫出現中文亂碼解決方案,一起看看吧
    2017-09-09
  • MYSQL中COMPACT行格式的具體使用

    MYSQL中COMPACT行格式的具體使用

    compact行格式是mysql中InnoDB存儲引擎存儲數據使用的一種行格式,本文主要介紹了MYSQL中COMPACT行格式的具體使用,具有一定的參考價值,感興趣的可以了解一下
    2024-08-08
  • mysql數據遷移到Oracle的正確方法

    mysql數據遷移到Oracle的正確方法

    這篇文章主要為大家詳細介紹了mysql數據遷移到Oracle的正確方法,文中步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-02-02
  • MySQL中的套接字錯誤解決

    MySQL中的套接字錯誤解決

    socket文件是一種特殊的文件,可以促進不同進程之間的通信,有時候系統(tǒng)或MySQL配置的更改可能導致MySQL無法讀取套接字文件,本文主要介紹了MySQL中的套接字錯誤解決,感興趣的可以了解一下
    2024-02-02
  • 提高MySQL中數據裝載效率

    提高MySQL中數據裝載效率

    很多時候關心的是優(yōu)化SELECT 查詢,因為它們是最常用的查詢,而且確定怎樣優(yōu)化它們并不總是直截了當。
    2009-11-11
  • MySQL通過login_path登錄數據庫的實現示例

    MySQL通過login_path登錄數據庫的實現示例

    login_path是MySQL5.6開始支持的新特性,本文主要介紹了MySQL通過login_path登錄數據庫,文中通過示例代碼介紹的非常詳細,需要的朋友們下面隨著小編來一起學習學習吧
    2025-02-02
  • MySql?查詢符合條件的最新數據行

    MySql?查詢符合條件的最新數據行

    這篇文章主要介紹了MySql?怎么查出符合條件的最新的數據行,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-07-07
  • Ubuntu 18.04 安裝mysql5.7

    Ubuntu 18.04 安裝mysql5.7

    這篇文章主要為大家詳細介紹了Ubuntu 18.04 安裝mysql 5.7的相關資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-02-02
  • 使用squirrel進行sql拼接不生效問題及解決

    使用squirrel進行sql拼接不生效問題及解決

    這篇文章主要介紹了使用squirrel進行sql拼接不生效問題及解決方案,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • 計算機管理服務中找不到mysql的服務的解決辦法

    計算機管理服務中找不到mysql的服務的解決辦法

    MySQL是一種流行的開源關系型數據庫管理系統(tǒng),用于存儲和管理大量數據,在計算機管理中,啟動MySQL服務是一項重要的任務,因為它可以確保數據庫系統(tǒng)的順利運行,這篇文章主要給大家介紹了關于計算機管理服務中找不到mysql的服務的解決辦法,需要的朋友可以參考下
    2023-05-05

最新評論