精品欧美一区二区三区在线观看 _久久久久国色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技術棧公眾號

91久久免费视频| 日本免费黄视频| 精品美女www爽爽爽视频| 国产精品大片| 国产亚洲人成a一在线v站| 在线观看视频在线观看| 91av亚洲| 一区二区三区.www| 欧美在线一区二区三区四区| 国产又黄又粗又长| 亚洲影视综合| 久久亚洲精品中文字幕冲田杏梨| 亚洲视频在线播放免费| 性欧美video另类hd尤物| 亚洲第一在线综合网站| 一区二区不卡视频| 视频三区在线观看| 国产精品一区二区三区99| 国产97在线播放| 久久精品www人人爽人人| 成人av国产| 亚洲精品电影网| 男插女视频网站| 蜜桃视频成人m3u8| 精品国产鲁一鲁一区二区张丽| 一本久久a久久精品vr综合| 天天躁日日躁狠狠躁喷水| 国产一区二区三区在线观看免费视频 | 日韩精品导航| 精品日本一线二线三线不卡| 久久久久久综合网| yiren22亚洲综合| 色素色在线综合| 日韩avxxx| 99热99re6国产在线播放| 亚洲欧美色图小说| 在线看无码的免费网站| 国产区视频在线| 久久综合九色综合久久久精品综合 | 国产乱叫456在线| 人人精品人人爱| 日本伊人精品一区二区三区介绍| 免费日韩一级片| 激情成人亚洲| 久久露脸国产精品| 精品午夜福利视频| 韩国av一区| 久久久久久久久国产| 麻豆一区产品精品蜜桃的特点 | 精品国产亚洲一区二区三区在线| 欧美日韩在线播放三区四区| 蜜桃免费在线视频| 88xx成人网| 欧美色倩网站大全免费| 色一情一乱一伦一区二区三区日本| 自拍一区在线观看| 色综合 综合色| 成人性做爰aaa片免费看不忠| 久久人体大尺度| 色8久久人人97超碰香蕉987| 精品久久久久久无码国产| 日韩一区二区三区免费视频| 欧美三区免费完整视频在线观看| 国产又猛又黄的视频| 亚洲天堂1区| 777久久久精品| 日韩av影视大全| jizz性欧美2| 精品小视频在线| 先锋影音av在线| 99久久影视| 欧美黑人一区二区三区| 日韩欧美三级在线观看| 先锋亚洲精品| 国产精品亚洲片夜色在线| 国产美女免费视频| 成人午夜av影视| 欧美污视频久久久| 日本在线人成| 亚洲一区av在线| 国产美女三级视频| 亚洲国产一区二区久久| 亚洲精品一区二区三区在线观看 | 精品欧美在线观看| 97国产精品videossex| 日本一区二区三区免费观看| 在线观看二区| 亚洲午夜羞羞片| 免费看a级黄色片| 刘玥91精选国产在线观看| 久久综合九色| 91嫩草视频在线观看| 欧美视频免费一区二区三区| 国产精品久久久久婷婷| 国产一级爱c视频| av成人免费| 亚洲精品av在线| 色婷婷粉嫩av| 亚洲在线免费| 99re视频在线观看| 91在线视频| 午夜电影网亚洲视频| 污视频免费在线观看网站| 18国产精品| 中文字幕一精品亚洲无线一区 | 夜夜精品视频| 91精品视频免费看| 婷婷五月综合激情| 亚洲乱码精品一二三四区日韩在线| 内射国产内射夫妻免费频道| 国产亚洲久久| 国产一区二区三区在线免费观看| 国产一二三四在线| 韩国一区二区在线观看| 奇米精品在线| 日韩欧美精品一区二区三区| 日韩欧美的一区| 亚洲综合图片一区| 老司机精品福利视频| 国产精品裸体一区二区三区| 免费在线观看av片| 91福利在线播放| 午夜一区二区三区免费| 好吊一区二区三区| 亚洲free性xxxx护士hd| 天堂中文а√在线| 在线观看免费亚洲| 亚洲综合网在线观看| 亚洲精品孕妇| 福利视频久久| 中文字幕资源网在线观看| 欧美日韩成人综合天天影院| 无码 人妻 在线 视频| 亚洲女人av| 精品国产乱码久久久久久丨区2区 精品国产乱码久久久久久蜜柚 | 日本中文字幕久久| 久久一夜天堂av一区二区三区| 亚洲熟妇无码一区二区三区导航| 亚洲**毛片| 欧美黄色三级网站| 成人免费观看在线视频| 亚洲制服欧美中文字幕中文字幕| 97超碰人人看| 一区二区免费不卡在线| 成人羞羞国产免费| a毛片在线看免费观看| 8v天堂国产在线一区二区| 在线日韩国产网站| 国产美女娇喘av呻吟久久| 香蕉视频免费版| 一区三区自拍| 国产做受高潮69| 五月天婷婷在线观看| 婷婷开心激情综合| 国产精品1000部啪视频| 久久中文精品| 亚洲国产精品一区二区第一页 | 激情综合色综合久久| 男女激烈动态图| 91精品入口| 91av在线免费观看| 国产中文在线| 欧美日韩成人激情| 欧美日韩中文字幕在线观看| 成人自拍视频在线| 六月丁香婷婷激情| 成人亚洲一区| 99国产视频在线| 国产理论在线| 一区二区三区www| 国产色片在线观看| 亚洲国产欧美在线人成| 人人妻人人藻人人爽欧美一区| 欧美aaa在线| 天天想你在线观看完整版电影免费| 丁香综合av| 国产成人亚洲综合91精品| 欧美边添边摸边做边爱免费| 欧美成人激情免费网| 最新中文字幕一区| 综合激情成人伊人| 国产视频久久久久久| 日本成人在线电影网| www.一区二区.com| 伊人久久大香线蕉无限次| 国产日韩精品电影| av中文在线资源库| 色偷偷偷亚洲综合网另类 | 成人黄色91| 97热在线精品视频在线观看| 国产高清视频免费最新在线| 欧美一二三四在线| 欧美超碰在线观看| 亚洲愉拍自拍另类高清精品| 色婷婷精品久久二区二区密| 日本不卡一区二区| 欧美午夜性视频| 99久久婷婷| 欧美在线视频一区二区三区| jizz性欧美23| 成人黄色激情网| 欧美大片免费高清观看| 欧美国产日韩一区二区三区| 91av资源在线| 亚洲色图色老头| 黄色av一区二区三区| 欧美欧美午夜aⅴ在线观看| 国产毛片aaa| 亚洲国产一区二区a毛片| 亚洲女人毛茸茸高潮| 2024国产精品| 久久久久久久久久久久国产精品| 久久国产精品99久久人人澡| 日韩av资源在线| 亚洲高清资源| 亚洲国产精品女人| 日韩电影在线视频| 欧美一区二区三区在线播放 | 性高潮视频在线观看| 午夜伦欧美伦电影理论片| 国产精品久久久精品四季影院| 亚洲国产精品二十页| 三级网站在线免费观看| 99久久综合狠狠综合久久| 潘金莲一级淫片aaaaa| 老司机精品视频导航| 亚洲男人天堂色| 香蕉视频成人在线观看| 欧美亚洲国产成人| 亚洲三级网站| 中文字幕日本最新乱码视频| 在线精品亚洲| 欧美一级视频在线播放| 国产精品v亚洲精品v日韩精品 | 2021天堂中文幕一二区在线观| 免费91在线视频| 超碰最新在线| 欧美成人精品三级在线观看| www国产在线观看| 麻豆国产va免费精品高清在线| 欧美69xxx| 久热精品视频在线观看| 成年视频在线观看| 欧美大片网站在线观看| 丁香花在线高清完整版视频| 欧美激情亚洲激情| а√天堂8资源在线| 国模精品视频一区二区三区| 91高清视频在线观看| 久久青草福利网站| 午夜伦理福利在线| 日本精品久久中文字幕佐佐木| 日韩在线影院| 国产精品自产拍在线观| 成人av在线播放| 99蜜桃在线观看免费视频网站| av成人综合| 久久久久久九九| 欧美老女人另类| 宅男噜噜99国产精品观看免费| 久久久久久免费视频| 亚洲国产一二三精品无码| 在线成人www免费观看视频| 国产男女无遮挡| 免费观看成人鲁鲁鲁鲁鲁视频| 潘金莲激情呻吟欲求不满视频| 国产成人鲁色资源国产91色综| 国产一卡二卡三卡四卡| 久久久青草青青国产亚洲免观| 国产午夜精品久久久久久久久| 亚洲丝袜制服诱惑| 日本一区二区免费在线观看| 欧美性猛交xxxx免费看久久久| 在线视频欧美亚洲| 欧美精品一区二区三区在线播放| 天堂在线中文| 久久视频这里只有精品| av资源中文在线| 国产精品亚发布| 国产精品调教| 一区二区三区四区五区精品| 欧美天天视频| 欧美少妇性生活视频| 极品销魂美女一区二区三区| 成人免费毛片日本片视频| 国产精品青草久久| 国产无码精品一区二区| 欧美日精品一区视频| 黄色a在线观看| 色老头一区二区三区在线观看| 国产精品69xx| 国产美女被下药99| 午夜精品影视国产一区在线麻豆| 日本一区二区免费高清视频| 亚洲男女自偷自拍| 韩国三级hd中文字幕有哪些| 国产香蕉久久精品综合网| 国产女人18水真多毛片18精品| 日韩欧美高清视频| 国产成人精品无码高潮| 国产一区二区美女视频| av中文资源在线资源免费观看| 成人在线一区二区| 深爱激情综合| 欧美视频在线观看视频| 激情综合网av| 人人妻人人澡人人爽| 婷婷开心激情综合| 精品人妻一区二区三区含羞草| 中文字幕日韩高清| 无遮挡在线观看| 国产视频在线观看一区| 中文字幕人成人乱码| 91亚洲免费视频| 久久久久国产成人精品亚洲午夜| 国产午夜福利片| 日韩一区二区视频| 日本免费中文字幕在线| 国产成人午夜视频网址| 亚洲男人都懂第一日本| 亚洲人成无码网站久久99热国产| 韩国毛片一区二区三区| 2014亚洲天堂| 欧美日韩精品高清| 成人精品一区二区三区免费| 日本成人激情视频| 日韩美脚连裤袜丝袜在线| 99在线免费视频观看| 国产一区二区三区免费观看| 国产高清视频免费在线观看| 欧美日韩三级一区二区| www.久久热.com| 国产精品久久99久久| 精品在线播放| 欧美a在线视频| 久久免费视频一区| www.久久久久久久| 亚洲性无码av在线| 日韩成人影音| 亚洲国产成人不卡| 久久精品999| 国产在线一卡二卡| 日韩无一区二区| 欧美hdxxxxx| 国产精品一 二 三| 亚洲国产裸拍裸体视频在线观看乱了中文| 少妇极品熟妇人妻无码| 亚洲成av人影院| 青青国产在线| 国产精品久久久久久av福利| 日韩精品dvd| 国产在线精品91| 久久久久久免费毛片精品| 亚洲高清在线看| www.久久撸.com| 亚洲精选av| 日韩av片在线看| 国产精品日韩精品欧美在线| 一级α片免费看刺激高潮视频| 精品国偷自产在线| 久久综合给合| 久久久999免费视频| 国产校园另类小说区| 国产精品无码AV| 久久99热精品这里久久精品| 日韩激情网站| xx欧美撒尿嘘撒尿xx| 亚洲欧美日韩中文字幕一区二区三区| 午夜精品久久久久久久99老熟妇| 午夜精品国产精品大乳美女| 美女少妇全过程你懂的久久| 天堂一区在线观看| 亚洲综合清纯丝袜自拍| 偷拍自拍在线| 欧美在线视频一区| 99精品美女| 五月婷婷综合在线观看| 欧美日韩不卡一区| 久久久男人天堂| 亚洲一卡二卡三卡四卡无卡网站在线看| 国产精品一二二区| 高清乱码免费看污| 欧美成人性生活| av在线亚洲色图| 午夜免费一区二区| 一区二区免费看| 国产福利在线看| αv一区二区三区| 免费精品视频最新在线| 精品无码黑人又粗又大又长| 中文字幕亚洲综合久久筱田步美| 综合久久成人| 黄色永久免费网站| 亚洲3atv精品一区二区三区| 天堂аⅴ在线地址8| 精品在线观看一区二区| 国产在线精品一区二区夜色| 国产成人精品网| 欧美激情网友自拍| 久久国产成人精品|