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

MySQL分表和分區(qū)的具體實(shí)現(xiàn)方法

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

垂直分表

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

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

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

水平分表

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

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

劣勢(shì):會(huì)給前端程序應(yīng)用程序的SQL代碼的維護(hù)帶來很大的麻煩,這時(shí)候可以使用MySQL的Merge存儲(chǔ)引擎實(shí)現(xiàn)分表。

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

用Merge存儲(chǔ)引擎分表,對(duì)應(yīng)用程序的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表的時(shí)候可能報(bào)錯(cuò):

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

實(shí)際上merge存儲(chǔ)引擎是一個(gè)虛擬的表,對(duì)應(yīng)的實(shí)際表必須是myisam類型的表,如果你的mysql是5.1以上版本,默認(rèn)數(shù)據(jù)庫使用的事InnoDB存儲(chǔ)引擎的,所以在創(chuàng)建total時(shí),t1和t2表必須是myisam存儲(chǔ)引擎的。

如果需要定期增加分表,只需要修改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條數(shù)據(jù),分成十份,前10W條數(shù)據(jù)放到第一個(gè)分區(qū),第二個(gè)10W條數(shù)據(jù)放到第二個(gè)分區(qū),依此類推。取出一條數(shù)據(jù)的時(shí)候,這條數(shù)據(jù)包含了表結(jié)構(gòu)中的所有字段,橫向分區(qū)并沒有改變表的結(jié)構(gòu)。

縱向分區(qū)

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

完整的一張表,都對(duì)應(yīng)三個(gè)文件,一個(gè).MYD數(shù)據(jù)文件,.MYI索引文件,.frm表結(jié)構(gòu)文件。

相關(guān)文章

  • 在CMD中操作mysql數(shù)據(jù)庫出現(xiàn)中文亂碼解決方案

    在CMD中操作mysql數(shù)據(jù)庫出現(xiàn)中文亂碼解決方案

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

    MYSQL中COMPACT行格式的具體使用

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

    mysql數(shù)據(jù)遷移到Oracle的正確方法

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

    MySQL中的套接字錯(cuò)誤解決

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

    提高M(jìn)ySQL中數(shù)據(jù)裝載效率

    很多時(shí)候關(guān)心的是優(yōu)化SELECT 查詢,因?yàn)樗鼈兪亲畛S玫牟樵?,而且確定怎樣優(yōu)化它們并不總是直截了當(dāng)。
    2009-11-11
  • MySQL通過login_path登錄數(shù)據(jù)庫的實(shí)現(xiàn)示例

    MySQL通過login_path登錄數(shù)據(jù)庫的實(shí)現(xiàn)示例

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

    MySql?查詢符合條件的最新數(shù)據(jù)行

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

    Ubuntu 18.04 安裝mysql5.7

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

    使用squirrel進(jìn)行sql拼接不生效問題及解決

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

    計(jì)算機(jī)管理服務(wù)中找不到mysql的服務(wù)的解決辦法

    MySQL是一種流行的開源關(guān)系型數(shù)據(jù)庫管理系統(tǒng),用于存儲(chǔ)和管理大量數(shù)據(jù),在計(jì)算機(jī)管理中,啟動(dòng)MySQL服務(wù)是一項(xiàng)重要的任務(wù),因?yàn)樗梢源_保數(shù)據(jù)庫系統(tǒng)的順利運(yùn)行,這篇文章主要給大家介紹了關(guān)于計(jì)算機(jī)管理服務(wù)中找不到mysql的服務(wù)的解決辦法,需要的朋友可以參考下
    2023-05-05

最新評(píng)論