精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

MySQL查詢語句中的IN和Exists對比分析

數據庫 MySQL
最近在寫SQL語句時,對選擇IN 還是Exists 猶豫不決,于是把兩種方法的SQL都寫出來對比一下執行效率,發現IN的查詢效率比Exists高了很多,于是想當然的認為IN的效率比Exists好,但本著尋根究底的原則,我想知道這個結論是否適用所有場景,以及為什么會出現這個結果。

 

MySQL查詢語句中的IN和Exists對比分析

背景介紹

最近在寫SQL語句時,對選擇IN 還是Exists 猶豫不決,于是把兩種方法的SQL都寫出來對比一下執行效率,發現IN的查詢效率比Exists高了很多,于是想當然的認為IN的效率比Exists好,但本著尋根究底的原則,我想知道這個結論是否適用所有場景,以及為什么會出現這個結果。

網上查了一下相關資料,大體可以歸納為:外部表小,內部表大時,適用Exists;外部表大,內部表小時,適用IN。那我就困惑了,因為我的SQL語句里面,外表只有1W級別的數據,內表有30W級別的數據,按網上的說法應該是Exists的效率會比IN高的,但我的結果剛好相反?。?/p>

“沒有調查就沒有發言權”!于是我開始研究IN 和Exists的實際執行過程,從實踐的角度出發,在根本上去尋找原因,于是有了這篇博文分享。

實驗數據

我的實驗數據包括兩張表:t_author表 和 t_poetry表。

對應表的數據量:

t_author表,13355條記錄;

t_poetry表,289917條記錄。

對應的表結構如下:

 

  1. CREATE TABLE t_poetry (  
  2. id bigint(20) NOT NULL AUTO_INCREMENT,  
  3. poetry_id bigint(20) NOT NULL COMMENT '詩詞id' 
  4. poetry_name varchar(200) NOT NULL COMMENT '詩詞名稱' 
  5. <font color=red> author_id bigint(20) NOT NULL COMMENT '作者id'</font>  
  6. PRIMARY KEY (id),  
  7. <font color=red>  
  8. UNIQUE KEY pid_idx (poetry_id) USING BTREE,  
  9. KEY aid_idx (author_id) USING BTREE</font>  
  10. ) ENGINE=InnoDB AUTO_INCREMENT=291270 DEFAULT CHARSET=utf8mb4  
  11. CREATE TABLE t_author (  
  12. id int(15) NOT NULL AUTO_INCREMENT,  
  13. <font color=red> author_id bigint(20) NOT NULL,</font>  
  14. author_name varchar(32) NOT NULL 
  15. dynasty varchar(16) NOT NULL 
  16. poetry_num int(8) NOT NULL DEFAULT '0'  
  17. PRIMARY KEY (id),  
  18. <font color=red>UNIQUE KEY authorid_idx (author_id) USING BTREE</font>  
  19. ) ENGINE=InnoDB AUTO_INCREMENT=13339 DEFAULT CHARSET=utf8mb4 

 

執行計劃分析

IN 執行過程

sql示例:

 

  1. select * from tabA where tabA.x in (select x from tabB where y>0 ); 

其執行計劃:

(1)執行tabB表的子查詢,得到結果集B,可以使用到tabB表的索引y;

(2)執行tabA表的查詢,查詢條件是tabA.x在結果集B里面,可以使用到tabA表的索引x。

Exists執行過程

sql示例:

 

  1. select from tabA where exists (select from tabB where y>0); 

其執行計劃:

(1)先將tabA表所有記錄取到。

(2)逐行針對tabA表的記錄,去關聯tabB表,判斷tabB表的子查詢是否有返回數據,5.5之后的版本使用Block Nested Loop(Block 嵌套循環)。

(3)如果子查詢有返回數據,則將tabA當前記錄返回到結果集。

tabA相當于取全表數據遍歷,tabB可以使用到索引。

實驗過程

實驗針對相同結果集的IN和Exists 的SQL語句進行分析。

包含IN的SQL語句:

 

  1. select from t_author ta where author_id in  
  2. (select author_id from t_poetry tp where tp.poetry_id>3650 ); 

 

包含Exists的SQL語句:

 

  1. select from t_author ta where exists  
  2. (select * from t_poetry tp where tp.poetry_id>3650 and tp.author_id=ta.author_id); 

 

第一次實驗

數據情況

t_author表,13355條記錄;t_poetry表,子查詢篩選結果集 where poetry_id>293650 ,121條記錄;

執行結果

使用exists耗時0.94S, 使用in耗時0.03S,<font color=red>IN 效率高于Exists</font>。

原因分析

對t_poetry表的子查詢結果集很小,且兩者在t_poetry表都能使用索引,對t_poetry子查詢的消耗基本一致。兩者區別在于,使用 in 時,t_author表能使用索引:

MySQL查詢語句中的IN 和Exists 對比分析

 

使用exists時,t_author表全表掃描:

MySQL查詢語句中的IN 和Exists 對比分析

 

在子查詢結果集較小時,查詢耗時主要表現在對t_author表的遍歷上。

第二次實驗

數據情況

t_author表,13355條記錄;t_poetry表,子查詢篩選結果集 where poetry_id>3650 ,287838條記錄;

執行時間

使用exists耗時0.12S, 使用in耗時0.48S,<font color=red>Exists IN</font>。

原因分析

兩者的索引使用情況跟第一次實驗是一致的,唯一區別是子查詢篩選結果集的大小不同,但實驗結果已經跟第一次的不同了。這種情況下子查詢結果集很大,我們看看mysql的查詢計劃:

使用in時,由于子查詢結果集很大,對t_author和t_poetry表都接近于全表掃描,此時對t_author表的遍歷耗時差異對整體效率影響可以忽略,執行計劃里多了一行<auto_key>,在接近全表掃描的情況下,mysql優化器選擇了auto_key來遍歷t_author表:

MySQL查詢語句中的IN 和Exists 對比分析

 

使用exists時,數據量的變化沒有帶來執行計劃的改變,但由于子查詢結果集很大,5.5以后的MySQL版本在exists匹配查詢結果時使用的是Block Nested-Loop(Block嵌套循環,引入join buffer,類似于緩存功能)開始對查詢效率產生顯著影響,尤其針對<font color=red>子查詢結果集很大</font>的情況下能顯著改善查詢匹配效率:

MySQL查詢語句中的IN 和Exists 對比分析

 

實驗結論

根據上述兩個實驗及實驗結果,我們可以較清晰的理解IN 和Exists的執行過程,并歸納出IN 和Exists的適用場景:

  • IN查詢在內部表和外部表上都可以使用到索引;
  • Exists查詢僅在內部表上可以使用到索引;
  • 子查詢結果集很大,而外部表較小的時候,Exists的Block Nested Loop(Block 嵌套循環)的作用開始顯現,并彌補外部表無法用到索引的缺陷,查詢效率會優于IN。
  • 子查詢結果集較小,而外部表很大的時候,Exists的Block嵌套循環優化效果不明顯,IN 的外表索引優勢占主要作用,此時IN的查詢效率會優于Exists。
  • 網上的說法不準確。其實“表的規模”不是看內部表和外部表,而是外部表和子查詢結果集。
  • 最后一點,也是最重要的一點:世間沒有絕對的真理,掌握事物的本質,針對不同的場景進行實踐驗證才是最可靠有效的方法。

實驗過程中發現的問題補充

僅對不同數據集情況下的上述exists語句分析時發現,數據集越大,消耗的時間反而變小,覺得很奇怪。

具體查詢條件為:

where tp.poetry_id>3650,耗時0.13S

where tp.poetry_id>293650,耗時0.46S

可能原因:條件值大,查詢越靠后,需要遍歷的記錄越多,造成最終消耗越多的時間。這個解釋有待進一步驗證后再補充。 

責任編輯:龐桂玉 來源: 今日頭條
相關推薦

2010-11-25 15:57:49

mysql查詢語句

2010-07-14 10:26:58

IMAP協議

2018-01-26 14:29:01

框架

2018-01-21 14:11:22

人工智能PaddlePaddlTensorflow

2023-05-14 22:00:01

2010-06-08 11:15:43

OpenSUSE Ub

2010-08-04 15:47:24

NFS版本

2016-10-18 21:10:17

GitHubBitbucketGitLab

2010-07-20 16:16:21

SDH

2024-08-08 07:38:42

2015-03-09 15:06:20

javaphpweb開發

2017-05-05 10:15:38

深度學習框架對比分析

2017-03-20 14:32:57

2010-06-24 21:35:33

2013-01-17 16:11:11

數據中心交換機網絡虛擬化

2021-05-18 10:18:15

Java

2021-03-15 08:40:46

數據分析波動

2011-09-08 16:30:59

SQL Server查詢

2023-05-18 07:30:16

OpenCLGPU平臺生態

2023-06-05 07:35:03

點贊
收藏

51CTO技術棧公眾號

懂色av一区二区| 老司机精品影院| 男人的天堂亚洲在线| 中日韩午夜理伦电影免费| 视频免费1区二区三区 | 国产精品另类一区| 国产精品免费视频一区二区| 无码人妻精品一区二区三区不卡 | 人人精品视频| 制服丝袜中文字幕亚洲| 久色视频在线播放| 毛片在线视频| 国产女主播视频一区二区| 91成人免费观看| 最新中文字幕免费| 夜久久久久久| 久久综合久中文字幕青草| 在线观看福利片| 国产成人视屏| 欧美日韩一区二区在线观看| 欧美二区在线视频| a级毛片免费观看在线| 久久久精品免费免费| 国产精品久久久久久久久久直播 | 亚洲女同志freevdieo| 亚洲卡通欧美制服中文| 亚洲一区二区三区精品视频| 欧美老女人性开放| 成人av网站免费观看| 亚洲xxxx做受欧美| 在线免费观看av片| 日本不卡视频在线观看| 2023亚洲男人天堂| 久久久久久激情| 天天揉久久久久亚洲精品| 一区二区三区国产视频| 一女三黑人理论片在线| 国产主播性色av福利精品一区| 欧美一区二区国产| 天堂在线中文在线| 久久亚洲国产精品尤物| 欧美在线观看视频在线| 亚洲中文字幕久久精品无码喷水| 夜鲁夜鲁夜鲁视频在线播放| 亚洲成人你懂的| 欧美一二三不卡| 中国av在线播放| 亚洲美女免费在线| 久久久无码中文字幕久...| 午夜免费播放观看在线视频| 国产精品色眯眯| 亚洲精品二区| 毛片免费不卡| 亚洲美女偷拍久久| 国产成人永久免费视频| 免费毛片在线看片免费丝瓜视频| 尤物av一区二区| 久久久久久av无码免费网站下载| 日本在线观看高清完整版| 一区二区三区欧美日| 欧洲精品在线播放| 男人久久天堂| 欧美主播一区二区三区美女| 看欧美ab黄色大片视频免费| 久久麻豆视频| 日韩欧美一级精品久久| 亚洲av无码一区东京热久久| 欧美三级自拍| 国产亚洲精品久久久久动| 免费看91的网站| 国产精品成人一区二区不卡| 欧美精品在线播放| 狠狠躁夜夜躁人人爽天天高潮| 国产精品社区| 国产精品综合久久久| 国产青青草视频| 成人午夜激情影院| 日本精品一区二区三区高清 久久| 成人午夜影视| 亚洲三级久久久| 久久久久99精品成人片| 依依综合在线| 69精品人人人人| 免费a v网站| 成人网18免费网站| 欧美激情网友自拍| 成年人视频免费| 国产伦精品一区二区三区免费| 国产精品一区在线播放| 电影在线一区| 亚洲一区免费观看| 国产真人无码作爱视频免费| 伊人精品综合| 在线性视频日韩欧美| 久久久久久久久久久97| 日韩精品乱码av一区二区| 99精品国产高清一区二区| 嫩草在线播放| 亚洲一区视频在线观看视频| 国产一二三四在线视频| 精品丝袜久久| 久久久av网站| 国产91精品看黄网站在线观看| 国产精品影视天天线| 日韩国产在线一区| cao在线视频| 欧美精品日韩一本| 自拍偷拍亚洲天堂| 亚洲调教视频在线观看| 国产精品十八以下禁看| 头脑特工队2免费完整版在线观看| 国产精品久久久久久妇女6080| 鲁一鲁一鲁一鲁一澡| 国产亚洲高清一区| 最近2019中文字幕第三页视频| 日韩视频免费观看高清| 国产乱码精品一区二区三区五月婷| 欧美一级二级三级九九九| 欧美xxxbbb| 欧美丰满少妇xxxbbb| 在线国产视频一区| 亚洲一区二区三区高清| 国产日产精品一区二区三区四区| 国产写真视频在线观看| 欧美中文字幕一区二区三区亚洲| 中文乱码人妻一区二区三区视频| 欧美精品1区| 成人午夜在线影院| 欧美成年黄网站色视频| 欧美私人免费视频| 亚洲精品色午夜无码专区日韩| 国产一区二区三区的电影| 成人av免费在线看| 人人澡人人添人人爽一区二区| 欧美久久久久中文字幕| 欧美xxxooo| 免费观看日韩av| 亚洲v国产v| av久久网站| 色哟哟亚洲精品一区二区| 中国一级片黄色一级片黄| 国产亚洲一本大道中文在线| 欧美日韩激情视频在线观看| 日本一道高清一区二区三区| 69久久夜色精品国产69| 日本不卡视频一区二区| 大伊人狠狠躁夜夜躁av一区| 日本丰满少妇裸体自慰| 一本色道久久综合亚洲精品不卡| 国产亚洲精品久久飘花| 大桥未久在线视频| 日韩不卡在线观看| 天堂网视频在线| 久久精品夜色噜噜亚洲a∨ | 国产成人啪午夜精品网站男同| 熟女熟妇伦久久影院毛片一区二区| 婷婷久久免费视频| 免费97视频在线精品国自产拍| a天堂在线观看视频| 亚洲一区自拍偷拍| 亚洲一区二区观看| 日本亚洲免费观看| 中文字幕第一页亚洲| 136福利精品导航| 91po在线观看91精品国产性色| 午夜小视频免费| 欧美中文字幕不卡| 欧美一级片在线视频| 国产成人精品www牛牛影视| 国产高清www| 最新国产精品视频| 国产精品一区二区三区免费视频 | 亚洲av无码国产精品久久| 丝袜诱惑亚洲看片| 综合视频免费看| 久久超级碰碰| 国产精品福利久久久| jizzjizz亚洲| 亚洲乱码国产乱码精品精天堂| 在线观看亚洲一区二区| 亚洲成人久久影院| 极品人妻videosss人妻| 大陆成人av片| 日韩一级理论片| 欧美精品网站| 日韩在线电影一区| 中文字幕久久精品一区二区| 国产成人精品一区二区| 成人毛片av在线| 亚洲天堂色网站| 性生活免费网站| 色女孩综合影院| 免费视频网站www| 国产拍揄自揄精品视频麻豆| 国产成人精品一区二区三区在线观看 | 国内露脸中年夫妇交换精品| 国产精品久久9| av影视在线| 亚洲黄色录像片| 国产成人精品免费看在线播放| 88久久精品| 国产精品99久久99久久久二8| www免费在线观看| 亚洲欧美日韩高清| xxxwww在线观看| 欧美体内she精视频| 精品日韩毛片| 精品久久久999| 日韩精品视频无播放器在线看 | 奇米影视四色在线| 亚洲理论在线| 亚洲国产一二三精品无码| 国产亚洲一区| 久久精品成人一区二区三区蜜臀| 久久精品九色| 国产欧美韩国高清| 婷婷六月国产精品久久不卡| 欧美精品aaa| 影音先锋男人在线资源| 综合网日日天干夜夜久久| 色播色播色播色播色播在线| 亚洲精品在线免费观看视频| 国产精品人人妻人人爽| 欧美性三三影院| 人人草在线观看| 欧美性猛交xxxx富婆弯腰| 国产在线视频第一页| 一区二区三区四区不卡在线 | 亚洲成人原创| www.激情网| 午夜精品影院| 成年人免费观看的视频| 日韩精品2区| 亚洲成色最大综合在线| 欧美精选一区二区三区| 日韩精品不卡| 精品国产一级毛片| 日韩在线第一区| 成人女性视频| 在线免费观看一区二区三区| 久久福利影院| 中文字幕日韩一区二区三区| 日韩专区精品| 久久久国产精华液999999| 五月精品视频| 黑人巨茎大战欧美白妇| 欧美日韩91| 日本少妇高潮喷水视频| 亚洲免费网站| www.色偷偷.com| 日本aⅴ亚洲精品中文乱码| 亚洲欧美自拍另类日韩| 韩国v欧美v日本v亚洲v| 精品国产午夜福利在线观看| 国产69精品久久久久毛片| 日批视频免费看| 99久久精品国产麻豆演员表| 欧美性xxxx图片| 国产欧美视频在线观看| 一级黄色片日本| 一级特黄大欧美久久久| 女人十八岁毛片| 欧美性极品少妇| 精品国产av 无码一区二区三区| 日韩精品一区二区在线| 凸凹人妻人人澡人人添| 日韩电视剧在线观看免费网站| 国产一区二区影视| 久久久97精品| 美女在线视频免费| 国产精品美女在线| 亚洲乱码一区| 欧美日韩一区二 | 欧美一区自拍| 日本一区二区三区精品视频| 婷婷亚洲五月色综合| 男女日批视频在线观看| 日韩av成人高清| 波多野结衣中文字幕在线播放| av网站一区二区三区| 日韩福利在线视频| 亚洲国产一区二区视频| www.五月婷婷.com| 日韩免费福利电影在线观看| 奇米影视888狠狠狠777不卡| 久久精品免费播放| 神马久久午夜| 91久久精品美女| 亚洲精品中文字幕99999| av电影一区二区三区| 毛片一区二区| 午夜性福利视频| 久久精品免视看| 免费观看一级视频| 欧美日韩免费不卡视频一区二区三区 | 小早川怜子一区二区的演员表| 欧美日韩精品在线观看| 97人妻精品一区二区三区动漫| 亚洲精品乱码久久久久久按摩观| 免费在线观看av| 日韩av片电影专区| 国产精品任我爽爆在线播放| 久久av秘一区二区三区| 久久精品人人| 色综合久久五月| 亚洲女同女同女同女同女同69| 日韩精品一区不卡| 精品国产制服丝袜高跟| 色多多视频在线观看| 欧美壮男野外gaytube| 日本一区二区三区视频在线看 | xxxx黄色片| 亚洲黄色小视频| 国产精品色综合| 色婷婷综合久久久久| 桃子视频成人app| 精品国产一区二区三区麻豆免费观看完整版 | 日韩欧美极品在线观看| 国精品人妻无码一区二区三区喝尿| 日韩在线视频一区| 日韩av中字| 欧美高清视频一区| 一区二区三区成人精品| 中文字幕99页| 夜夜嗨av一区二区三区四季av| 国产精品视频a| 色偷偷av亚洲男人的天堂| 国产经典一区| 日本精品二区| 日韩不卡免费视频| 永久免费成人代码| 日韩欧美在线第一页| 天堂网www中文在线| 午夜精品一区二区三区在线| 成人在线视频中文字幕| 欧美国产视频一区| 国产a区久久久| 国产精品第一页在线观看| 欧美mv日韩mv| 高清毛片在线观看| 精品国产福利| 香蕉国产精品偷在线观看不卡| 亚洲av网址在线| 欧美日韩性视频| 国产一二三区在线视频| 国产精品久久视频| 久久美女精品| 女人高潮一级片| 亚洲精品免费在线播放| 日韩在线视频免费| 欧美有码在线视频| 精品视频免费| 午夜剧场高清版免费观看| 亚洲人成影院在线观看| 成 人 黄 色 片 在线播放| 欧美精品videos性欧美| 日韩欧美在线精品| 男人搞女人网站| 亚洲三级电影网站| 亚洲精品久久久久avwww潮水| 亚州精品天堂中文字幕| 国产精品手机在线播放 | 国产一区精品二区| 福利在线一区二区| 久久久久九九视频| 91精品国产乱码久久久久| 久久91亚洲精品中文字幕| 美女午夜精品| 亚洲欧美自偷自拍另类| 一区二区三区蜜桃| 色就是色亚洲色图| 成人做爰www免费看视频网站| 伊人精品在线| 国产精品天天干| 日韩女优制服丝袜电影| 成人片免费看| 手机在线视频你懂的| 91在线精品一区二区| 中文有码在线播放| 欧美激情高清视频| 精品视频97| 日本三级日本三级日本三级极| 在线免费亚洲电影| 日本小视频在线免费观看| 日本在线高清视频一区| 国产精品一区专区| 波多野结衣影片| 欧美国产日韩一区| 国产在线日韩精品| 中文字幕视频观看| 欧美日韩综合不卡| 国产伦久视频在线观看| 成年人黄色在线观看| 91免费观看国产| 国产特级黄色片| 国产精品久久久久久久7电影| 亚洲茄子视频| 国产精品99久久久久久成人| 亚洲片在线资源| 凹凸av导航大全精品|