国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)/技術(shù)文章
文章詳情頁(yè)

淺談mysql join底層原理

瀏覽:10日期:2023-10-17 18:36:04
目錄join算法驅(qū)動(dòng)表和非驅(qū)動(dòng)表的區(qū)別1、Simple Nested-Loop Join,簡(jiǎn)單嵌套-無索引的情況2、Index Nested-Loop Join-有索引的情況3、Block Nested-Loop Join ,join buffer緩沖區(qū)緩沖區(qū)大小數(shù)據(jù)量大的表和數(shù)據(jù)量小的表如何選擇連接順序細(xì)節(jié)join算法

mysql只支持一種join算法:Nested-Loop Join(嵌套循環(huán)連接),但Nested-Loop Join有三種變種:

Simple Nested-Loop Join,簡(jiǎn)單嵌套 Index Nested-Loop Join,索引嵌套 Block Nested-Loop Join ,join buffer緩沖區(qū)嵌套(臨時(shí)表)驅(qū)動(dòng)表和非驅(qū)動(dòng)表的區(qū)別

驅(qū)動(dòng)表就是主表,非驅(qū)動(dòng)表就是從表,看以下sql就知道了,A就是驅(qū)動(dòng)表,B就是非驅(qū)動(dòng)表。

select * from A left join B

A join B 連表時(shí),一定先查A表再查B表嗎?

答案是不一定,因?yàn)閙ysql內(nèi)部有一個(gè)優(yōu)化器,它會(huì)根據(jù)你查詢語(yǔ)句做一些優(yōu)化,先查哪張表也是由優(yōu)化器決定的,但可以肯定的是,先查詢的那張表就是驅(qū)動(dòng)表,反之就是非驅(qū)動(dòng)表;關(guān)于是那張表先查的問題,我們通過看執(zhí)行計(jì)劃來得出結(jié)果;在前面加上explain關(guān)鍵字即可;

explain select * from A join B;1、Simple Nested-Loop Join,簡(jiǎn)單嵌套-無索引的情況

A left join B: ,每次都是全表匹配,A表的每行數(shù)據(jù)都全表匹配一次B表,也就是說,假如我A表有10條數(shù)據(jù),B表有1000條數(shù)據(jù),那么查詢的時(shí)候掃描次數(shù)就是10*1000,也就說查詢時(shí)需要掃描10000遍才能得出數(shù)據(jù);

淺談mysql join底層原理

2、Index Nested-Loop Join-有索引的情況

select * from A join B on A.id=B.id where A.id = 1:在查詢時(shí),驅(qū)動(dòng)表A會(huì)根據(jù)關(guān)聯(lián)字段的索引進(jìn)行查找,當(dāng)在索引上找到符合的值,在回表進(jìn)行查詢,也就是說得匹配到索引后才會(huì)才會(huì)進(jìn)行回表查詢;如果非驅(qū)動(dòng)表B的關(guān)聯(lián)關(guān)聯(lián)字段B.id是主鍵的話,性能會(huì)非常高,如果不是主鍵,會(huì)進(jìn)行多次回表查詢,先關(guān)聯(lián)索引,然后根據(jù)二級(jí)索引的主鍵id進(jìn)行回表查詢,性能上比主鍵要慢;

淺談mysql join底層原理

3、Block Nested-Loop Join ,join buffer緩沖區(qū)

如果有索引,會(huì)選取Index Nested-Loop Join進(jìn)行連表,如果join列沒有索引,就會(huì)采用Block Nested-Loop Join ,join buffer,在驅(qū)動(dòng)表和非驅(qū)動(dòng)表中間有個(gè)buffer的緩沖區(qū),在查詢時(shí)先將驅(qū)動(dòng)表的數(shù)據(jù)緩存到buffer緩沖區(qū)內(nèi),然后批量與非驅(qū)動(dòng)表進(jìn)行匹配,這是一種將多次比較合并為一次比較的優(yōu)化方案,注意:這里緩存的不只是關(guān)聯(lián)表的列,select 后面的列也會(huì)緩存起來;

淺談mysql join底層原理

緩沖區(qū)大小

默認(rèn)情況下buffer緩沖區(qū)join_biffer_size的容量為256k,如果說你的數(shù)據(jù)空間大于256k,就無法使用緩沖區(qū)了,轉(zhuǎn)為最簡(jiǎn)單的循環(huán)嵌套Simple Nested-Loop Join,但是我們可以手動(dòng)調(diào)整緩沖區(qū)大小來裝入大容量的數(shù)據(jù);查看join_biffer_size的sql:show variables like ’%join_biffer_size%’

數(shù)據(jù)量大的表和數(shù)據(jù)量小的表如何選擇連接順序

最好由小表去連接大表,這樣會(huì)減少掃描次數(shù);比如大表有1000條數(shù)據(jù),小表只有10條數(shù)據(jù),那么最好的連接方式為:小表 join 大表;為什么要這么做呢?

如果是大表 join 小表,假如我們的數(shù)據(jù)在大表的第999行,那么查詢數(shù)據(jù)的時(shí)候就至少得掃描999次才能查出來; 如果是小表 join 大表,假如我們的數(shù)據(jù)在小表的第9行,細(xì)節(jié) 連表查詢的時(shí)候,最好不要超過三張表,因?yàn)樾枰猨oin的字段,數(shù)據(jù)類型必須一致 優(yōu)先使用內(nèi)連接來連表,外連接查詢數(shù)據(jù)消耗的性能比內(nèi)連接要高; 確保關(guān)聯(lián)查詢中on 后面的列或者 using()中的字段帶有索引,連表時(shí)可加快數(shù)據(jù)訪問

到此這篇關(guān)于淺談mysql join底層原理的文章就介紹到這了,更多相關(guān)mysql join底層原理內(nèi)容請(qǐng)搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: MySQL 數(shù)據(jù)庫(kù)
相關(guān)文章:
主站蜘蛛池模板: 久久精品在线视频 | 国产精品自在线 | 东凛中文字幕 | 黄色三级网站在线观看 | 国产精品二区在线 | 波多野结衣在线视频观看 | 国产三级观看 | 日本加勒比在线视频 | 中文字字幕码一二区 | 国产真实乱子伦精品视手机观看 | 日韩毛片在线免费观看 | 久久久久久久国产a∨ | 欧美一级毛片欧美一级成人毛片 | 欧美日产国产亚洲综合图区一 | 国产高清专区 | 亚欧精品在线观看 | 国产成人毛片视频不卡在线 | 国产欧美曰韩一区二区三区 | 手机在线毛片免费播放 | 毛片一区 | 国产在线欧美日韩精品一区二区 | 国产一区二区三区精品久久呦 | 免费成人毛片 | 亚洲九九 | 久久久久久久久久久久久久久久久久 | 国产专区一va亚洲v天堂 | 亚洲综合日韩欧美一区二区三 | 免费国产成人高清在线看软件 | 美女张开腿让男人桶爽动漫视频 | 亚洲毛片在线播放 | 亚洲综合一区二区三区 | 亚洲一区二区三区成人 | 国产一级精品视频 | 日本理论片免费高清影视在线观看 | www色在线 | 男人的天堂视频在线 | 中文字幕亚洲精品日韩精品 | 在线国产日韩 | 成年人免费观看的视频 | 日韩欧美在线视频一区二区 | 精品欧美一区二区三区免费观看 |