亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MySQL?臨時(shí)表的原理以及優(yōu)化方法

 更新時(shí)間:2022年08月22日 10:26:40   作者:劉Java  
這篇文章主要介紹了MySQL?臨時(shí)表的原理以及優(yōu)化方法,文章圍繞主題展開詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下

1 臨時(shí)表

sort buffer、內(nèi)存臨時(shí)表和join buffer,這三個(gè)數(shù)據(jù)結(jié)構(gòu)都是用來(lái)存放語(yǔ)句執(zhí)行過(guò)程中的中間數(shù)據(jù),以輔助SQL語(yǔ)句的執(zhí)行的。其中,在排序的時(shí)候用到了sort buffer,在使用join語(yǔ)句的時(shí)候用到了join buffer。

而使用臨時(shí)表的時(shí)候,ExplainExtra字段中具有Using temporary標(biāo)記。union、group by、distinct等等查詢都有可能使用到臨時(shí)表。

2 union臨時(shí)表優(yōu)化

使用union的時(shí)候,就需要用到內(nèi)存臨時(shí)表來(lái)進(jìn)行去重。

union語(yǔ)句的執(zhí)行流程為:

  • 創(chuàng)建一個(gè)內(nèi)存臨時(shí)表。
  • 執(zhí)行第一個(gè)子查詢,得到值,并存入臨時(shí)表中。
  • 執(zhí)行第二個(gè)子查詢:依次拿每一行數(shù)據(jù)和臨時(shí)表中的每一行數(shù)據(jù)比較,如果重復(fù)則不會(huì)插入,這樣就實(shí)現(xiàn)了去重的功能
  • 從臨時(shí)表中按行取出數(shù)據(jù),返回結(jié)果,并刪除臨時(shí)表。在最后這一步還可以對(duì)臨時(shí)表進(jìn)行其他操作,比如limit、ORDER BY。

如果使用union all,則不需要去重,也就不需要臨時(shí)表了。在執(zhí)行的時(shí)候,就依次執(zhí)行子查詢,得到的結(jié)果直接作為結(jié)果集的一部分,發(fā)給客戶端。因此,除非確實(shí)需要服務(wù)器消除重復(fù)的行,否則就一定要使用UNION ALL,這一點(diǎn)很重要。如果沒有ALL關(guān)鍵字,MySQL會(huì)給臨時(shí)表加上DISTINCT選項(xiàng),這會(huì)導(dǎo)致對(duì)整個(gè)臨時(shí)我的數(shù)據(jù)做唯一性檢查。這樣做的代價(jià)非常高。如果不需要這些檢查,那么甚至都不需要臨時(shí)表。

另外,避免對(duì)于union之后的結(jié)果集進(jìn)行操作,也能避免臨時(shí)表的使用,通常需要手工地將MHERE、LIMIT、ORDER BY等子句“下推”到UNION的各個(gè)子查詢中,以便優(yōu)化器可以充分利用這些條件進(jìn)行優(yōu)化,使得union的結(jié)果就是最終的結(jié)果(例如,直接將這些子句冗余地寫一份到各個(gè)子查詢)。

3 group by臨時(shí)表優(yōu)化

另外一個(gè)使用臨時(shí)表的例子是group by,group by還具有隱藏的排序的語(yǔ)句,即在對(duì)某些字段進(jìn)行分組之后,將數(shù)據(jù)再根據(jù)這些字段進(jìn)行排序,最后返回排序后的結(jié)果。

如下sql:

  select id%10 as m, count(*) as c from t1 group by m;  

這個(gè)語(yǔ)句的執(zhí)行流程是這樣的:

  • 創(chuàng)建內(nèi)存臨時(shí)表,表里有兩個(gè)字段m和c,主鍵是m;
  • 掃描表t1的索引a,依次取出葉子節(jié)點(diǎn)上的id值,計(jì)算id%10的結(jié)果,記為x;
    • 如果臨時(shí)表中沒有主鍵為x的行,就插入一個(gè)記錄(x,1);
    • 如果表中有主鍵為x的行,就將x這一行的c值加1;
    • 遍歷完成后,再根據(jù)字段m做排序,得到結(jié)果集返回給客戶端。

此時(shí),Explain的Extra字段中具有Using temporary; Using filesort標(biāo)記。

如果并不需要對(duì)結(jié)果進(jìn)行排序,那可以在SQL語(yǔ)句末尾增加order by null,即:

  select id%10 as m, count(*) as c from t1 group by m order by null;  

這樣就跳過(guò)了最后排序的階段,直接從臨時(shí)表中取數(shù)據(jù)返回。

內(nèi)存臨時(shí)表的大小是有限制的,參數(shù)tmp_table_size就是控制這個(gè)內(nèi)存大小的,默認(rèn)是16M。如果要處理的數(shù)據(jù)超過(guò)了最大大小,那么MySQL會(huì)把內(nèi)存臨時(shí)表轉(zhuǎn)成磁盤臨時(shí)表,而磁盤臨時(shí)表默認(rèn)使用的引擎是InnoDB,因此會(huì)按主鍵順序存儲(chǔ)數(shù)據(jù),所以最終取出的結(jié)果還是默認(rèn)有序的。

對(duì)于Group By的臨時(shí)表的優(yōu)化,同樣是使用索引:因?yàn)槿绻M(jìn)行Group By字段是有序的,那么在處理時(shí)(比如計(jì)算每組數(shù)量、個(gè)數(shù)等等),因?yàn)楦淖侄斡兴饕?,那么相同的值肯定是在一起的、連續(xù)的,所以直接順序掃描輸入的數(shù)據(jù)即可,不需要臨時(shí)表,也不需要再額外排序。

總結(jié):

  • 如果語(yǔ)句執(zhí)行過(guò)程可以一邊讀數(shù)據(jù),一邊直接得到結(jié)果,是不需要額外內(nèi)存的,否則就需要額外的內(nèi)存,來(lái)保存中間結(jié)果;
  • join_buffer是無(wú)序數(shù)組,sort_buffer是有序數(shù)組,臨時(shí)表是二維表結(jié)構(gòu);

如果執(zhí)行邏輯需要用到二維表特性,就會(huì)優(yōu)先考慮使用臨時(shí)表。比如我們的例子中,union需要用到唯一索引約束, group by還需要用到另外一個(gè)字段來(lái)存累積計(jì)數(shù)。

另外,對(duì)于distinct查詢來(lái)說(shuō),如果無(wú)法使用索引,則也會(huì)使用到臨時(shí)表,也會(huì)進(jìn)行分組,它和group by的區(qū)別是不需要排序。

到此這篇關(guān)于MySQL 臨時(shí)表的原理以及優(yōu)化方法的文章就介紹到這了,更多相關(guān)MySQL 臨時(shí)表 內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • MySQL解決Navicat設(shè)置默認(rèn)字符串時(shí)的報(bào)錯(cuò)問題

    MySQL解決Navicat設(shè)置默認(rèn)字符串時(shí)的報(bào)錯(cuò)問題

    本文主要介紹了MySQL解決Navicat設(shè)置默認(rèn)字符串時(shí)的報(bào)錯(cuò),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2022-06-06
  • Mysql SQL服務(wù)器模式介紹

    Mysql SQL服務(wù)器模式介紹

    這篇文章主要介紹了Mysql SQL服務(wù)器模式介紹,需要的朋友可以參考下MySQL服務(wù)器可以以不同的SQL模式來(lái)操作,并且可以為不同客戶端應(yīng)用不同模式,這樣每個(gè)應(yīng)用程序可以根據(jù)自己的需求來(lái)定制服務(wù)器的操作模式,需要的朋友可以參考下
    2014-12-12
  • MySQL筆記之?dāng)?shù)學(xué)函數(shù)詳解

    MySQL筆記之?dāng)?shù)學(xué)函數(shù)詳解

    本篇文章對(duì)MySQL的數(shù)學(xué)函數(shù)進(jìn)行了詳細(xì)的介紹。需要的朋友參考下
    2013-05-05
  • Win10系統(tǒng)下MySQL8.0.16 壓縮版下載與安裝教程圖解

    Win10系統(tǒng)下MySQL8.0.16 壓縮版下載與安裝教程圖解

    這篇文章主要介紹了Win10系統(tǒng)下MySQL8.0.16 壓縮版下載與安裝教程圖解,本文圖文并茂給大家介紹的非常詳細(xì),具有一定的參考解決價(jià)值,需要的朋友可以參考下
    2019-06-06
  • Mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)多字段過(guò)濾的方法

    Mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)多字段過(guò)濾的方法

    這篇文章主要介紹了Mysql數(shù)據(jù)庫(kù)實(shí)現(xiàn)多字段過(guò)濾的方法,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-07-07
  • 如何實(shí)現(xiàn)mysql的遠(yuǎn)程連接

    如何實(shí)現(xiàn)mysql的遠(yuǎn)程連接

    這篇文章詳細(xì)介紹了mysql如何實(shí)現(xiàn)遠(yuǎn)程連接,文中有詳細(xì)的代碼實(shí)例講解,有一定的參考價(jià)值,需要的朋友可以參考閱讀
    2023-04-04
  • 詳解MySQL數(shù)據(jù)庫(kù)設(shè)置主從同步的方法

    詳解MySQL數(shù)據(jù)庫(kù)設(shè)置主從同步的方法

    最近一直在研究mysql的主從同步問題,現(xiàn)在網(wǎng)上也有很多資料,現(xiàn)在感覺寫的都很好(當(dāng)初感覺寫的很差,是因?yàn)樽约旱念I(lǐng)悟較差),于是想跟大家分享一下自己配置的整個(gè)過(guò)程和經(jīng)驗(yàn)。有需要的朋友歐美可以參考借鑒,感興趣的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2016-11-11
  • MySQL中binlog備份腳本的方法

    MySQL中binlog備份腳本的方法

    這篇文章主要介紹了MySQL中binlog備份腳本分享,這里主要介紹一下我寫的MySQL二進(jìn)制日志的備份腳本,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • MySQL主從復(fù)制之半同步semi-sync?replication

    MySQL主從復(fù)制之半同步semi-sync?replication

    這篇文章主要介紹了MySQL主從復(fù)制之半同步semi-sync?replication,半同步相對(duì)于異步復(fù)制而言,提高了數(shù)據(jù)的安全性,同時(shí)也造成了一定程度的延遲,這個(gè)延遲最少是一個(gè)TCP往返的時(shí)間。所以,半同步復(fù)制最好在低延時(shí)的網(wǎng)絡(luò)中使用,下文詳細(xì)內(nèi)容,需要的小伙伴可以參考一下
    2022-02-02
  • mysql kill進(jìn)程后出現(xiàn)killed死鎖問題及解決

    mysql kill進(jìn)程后出現(xiàn)killed死鎖問題及解決

    這篇文章主要介紹了mysql kill進(jìn)程后出現(xiàn)killed死鎖問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-01-01

最新評(píng)論