亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

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

2024-07-25 19:08:30
字體:
供稿:網(wǎng)友

背景介紹

最近在寫SQL語句時(shí),對選擇IN 還是Exists 猶豫不決,于是把兩種方法的SQL都寫出來對比一下執(zhí)行效率,發(fā)現(xiàn)IN的查詢效率比Exists高了很多,于是想當(dāng)然的認(rèn)為IN的效率比Exists好,但本著尋根究底的原則,我想知道這個(gè)結(jié)論是否適用所有場景,以及為什么會出現(xiàn)這個(gè)結(jié)果。
網(wǎng)上查了一下相關(guān)資料,大體可以歸納為:外部表小,內(nèi)部表大時(shí),適用Exists;外部表大,內(nèi)部表小時(shí),適用IN。那我就困惑了,因?yàn)槲业腟QL語句里面,外表只有1W級別的數(shù)據(jù),內(nèi)表有30W級別的數(shù)據(jù),按網(wǎng)上的說法應(yīng)該是Exists的效率會比IN高的,但我的結(jié)果剛好相反??!
“沒有調(diào)查就沒有發(fā)言權(quán)”!于是我開始研究IN 和Exists的實(shí)際執(zhí)行過程,從實(shí)踐的角度出發(fā),在根本上去尋找原因,于是有了這篇博文分享。

實(shí)驗(yàn)數(shù)據(jù)

我的實(shí)驗(yàn)數(shù)據(jù)包括兩張表:t_author表 和 t_poetry表。
對應(yīng)表的數(shù)據(jù)量:

t_author表,13355條記錄;
t_poetry表,289917條記錄。

對應(yīng)的表結(jié)構(gòu)如下:

CREATE TABLE t_poetry (
id bigint(20) NOT NULL AUTO_INCREMENT,
poetry_id bigint(20) NOT NULL COMMENT '詩詞id',
poetry_name varchar(200) NOT NULL COMMENT '詩詞名稱',
<font color=red> author_id bigint(20) NOT NULL COMMENT '作者id'</font>
PRIMARY KEY (id),
UNIQUE KEY pid_idx (poetry_id) USING BTREE,
KEY aid_idx (author_id) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=291270 DEFAULT CHARSET=utf8mb4

CREATE TABLE t_author (
id int(15) NOT NULL AUTO_INCREMENT,
author_id bigint(20) NOT NULL,</font>
author_name varchar(32) NOT NULL,
dynasty varchar(16) NOT NULL,
poetry_num int(8) NOT NULL DEFAULT '0'
PRIMARY KEY (id),
<font color=red>UNIQUE KEY authorid_idx (author_id) USING BTREE
) ENGINE=InnoDB AUTO_INCREMENT=13339 DEFAULT CHARSET=utf8mb4

執(zhí)行計(jì)劃分析 IN 執(zhí)行過程

sql示例:select * from tabA where tabA.x in (select x from tabB where y>0 );

其執(zhí)行計(jì)劃:
(1)執(zhí)行tabB表的子查詢,得到結(jié)果集B,可以使用到tabB表的索引y;
(2)執(zhí)行tabA表的查詢,查詢條件是tabA.x在結(jié)果集B里面,可以使用到tabA表的索引x。

Exists執(zhí)行過程

sql示例:select from tabA where exists (select from tabB where y>0);

其執(zhí)行計(jì)劃:

(1)先將tabA表所有記錄取到。
(2)逐行針對tabA表的記錄,去關(guān)聯(lián)tabB表,判斷tabB表的子查詢是否有返回?cái)?shù)據(jù),5.5之后的版本使用Block Nested Loop(Block 嵌套循環(huán))。
(3)如果子查詢有返回?cái)?shù)據(jù),則將tabA當(dāng)前記錄返回到結(jié)果集。
tabA相當(dāng)于取全表數(shù)據(jù)遍歷,tabB可以使用到索引。

實(shí)驗(yàn)過程

實(shí)驗(yàn)針對相同結(jié)果集的IN和Exists 的SQL語句進(jìn)行分析。
包含IN的SQL語句:

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

包含Exists的SQL語句:

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

第一次實(shí)驗(yàn)數(shù)據(jù)情況

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

執(zhí)行結(jié)果

使用exists耗時(shí)0.94S, 使用in耗時(shí)0.03S,IN 效率高于Exists

原因分析

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

MySQL,IN,Exists

使用exists時(shí),t_author表全表掃描:

MySQL,IN,Exists

在子查詢結(jié)果集較小時(shí),查詢耗時(shí)主要表現(xiàn)在對t_author表的遍歷上。

第二次實(shí)驗(yàn)數(shù)據(jù)情況

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

執(zhí)行時(shí)間

使用exists耗時(shí)0.12S, 使用in耗時(shí)0.48S,Exists效率高于 IN。

原因分析

兩者的索引使用情況跟第一次實(shí)驗(yàn)是一致的,唯一區(qū)別是子查詢篩選結(jié)果集的大小不同,但實(shí)驗(yàn)結(jié)果已經(jīng)跟第一次的不同了。這種情況下子查詢結(jié)果集很大,我們看看mysql的查詢計(jì)劃:
使用in時(shí),由于子查詢結(jié)果集很大,對t_author和t_poetry表都接近于全表掃描,此時(shí)對t_author表的遍歷耗時(shí)差異對整體效率影響可以忽略,執(zhí)行計(jì)劃里多了一行<auto_key>,在接近全表掃描的情況下,mysql優(yōu)化器選擇了auto_key來遍歷t_author表:

MySQL,IN,Exists

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

MySQL,IN,Exists

實(shí)驗(yàn)結(jié)論

根據(jù)上述兩個(gè)實(shí)驗(yàn)及實(shí)驗(yàn)結(jié)果,我們可以較清晰的理解IN 和Exists的執(zhí)行過程,并歸納出IN 和Exists的適用場景:

IN查詢在內(nèi)部表和外部表上都可以使用到索引; Exists查詢僅在內(nèi)部表上可以使用到索引;當(dāng)子查詢結(jié)果集很大,而外部表較小的時(shí)候,Exists的Block Nested Loop(Block 嵌套循環(huán))的作用開始顯現(xiàn),并彌補(bǔ)外部表無法用到索引的缺陷,查詢效率會優(yōu)于IN。當(dāng)子查詢結(jié)果集較小,而外部表很大的時(shí)候,Exists的Block嵌套循環(huán)優(yōu)化效果不明顯,IN 的外表索引優(yōu)勢占主要作用,此時(shí)IN的查詢效率會優(yōu)于Exists。 網(wǎng)上的說法不準(zhǔn)確。其實(shí)“表的規(guī)模”不是看內(nèi)部表和外部表,而是外部表和子查詢結(jié)果集。最后一點(diǎn),也是最重要的一點(diǎn):世間沒有絕對的真理,掌握事物的本質(zhì),針對不同的場景進(jìn)行實(shí)踐驗(yàn)證才是最可靠有效的方法。 實(shí)驗(yàn)過程中發(fā)現(xiàn)的問題補(bǔ)充

僅對不同數(shù)據(jù)集情況下的上述exists語句分析時(shí)發(fā)現(xiàn),數(shù)據(jù)集越大,消耗的時(shí)間反而變小,覺得很奇怪。
具體查詢條件為:

where tp.poetry_id>3650,耗時(shí)0.13S
where tp.poetry_id>293650,耗時(shí)0.46S

可能原因:條件值大,查詢越靠后,需要遍歷的記錄越多,造成最終消耗越多的時(shí)間。這個(gè)解釋有待進(jìn)一步驗(yàn)證后再補(bǔ)充。


注:相關(guān)教程知識閱讀請移步到MYSQL教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产经典一区二区| 视频在线观看一区二区| 欧美大片一区二区三区| 亚洲国产精品第一区二区三区| 自拍亚洲一区欧美另类| 亚洲伦在线观看| 国产欧美日韩免费观看| 欧美亚洲国产一区在线观看网站| 美女无遮挡网站| 亚洲精品国产嫩草在线观看| 成人免费在线电影网| 国产高清在线观看视频| 无限国产资源| 久久久精品久久久久久96| 中国女人做爰视频| 色午夜这里只有精品| 亚洲欧美国产三级| 99re国产视频| 久久99精品久久久野外观看| 国产精品精品视频一区二区三区| 久久精选视频| 青娱乐精品视频| 日韩精品电影| 亚洲精品一二三四区| 99在线欧洲视频| 男人天堂欧美日韩| 国产精品50p| 91精品国偷自产在线电影| 国产偷窥女洗浴在线观看亚洲| 好看的中文字幕在线播放| 青草视频在线观看免费| av福利导福航大全在线播放| 久久国产福利国产秒拍| 免费不卡欧美自拍视频| av成人在线电影| 亚洲国产视频二区| 久久99爱视频| 中文在线天堂网| 国产一级大片| 国产一区二区三区高清| 91精品国产99久久久久久| 国产aaa一级片| 一区二区三区|亚洲午夜| 神马一区二区影院| 亚欧洲乱码视频| 无套内精的网站| www.98色噜噜噜| 妖精视频一区二区三区免费观看| 国产精品第一页在线| www.欧美日韩国产在线| 天天躁日日躁狠狠躁av| 91精品国产一区二区三区香蕉| 亚洲精品中文字幕乱码无线| 91中文字精品一区二区| canopen超线视频网线的应用| 欧美视频在线观看免费网址| 欧美成人女星排行榜| 成人在线高清视频| 亚洲麻豆一区二区三区| 成人av资源电影网站| 亚洲国产裸拍裸体视频在线观看乱了| 久久婷婷蜜乳一本欲蜜臀| 国产区精品区| 天堂a√在线| 亚洲在线网站| 欧美 日韩 国产 一区二区三区| 97影院理论片在线播放| 久久久久国产成人精品亚洲午夜| 亚洲色图50p| 国产精品亚洲一区二区无码| 色先锋资源在线播放av| 精品久久久久久久大神国产| 国产一区二区在线播放| 久久中文视频| 国产揄拍国内精品对白| 久久99精品国产99久久6尤物| 欧美影院久久久| 五月天婷婷激情网| 免费在线观看av电影| 国产激情第一页| 亚洲不卡视频在线观看| 视频在线观看一区二区| sese综合| 欧美日韩亚洲一区二区三区在线观看| 欧美牲交a欧美牲交aⅴ免费真| jizz性欧美10| 国产亚洲第一的欧洲日产| 一二三不卡视频| 五月天婷婷影视| 国产麻豆高清视频在线第一页| 少妇无套高潮一二三区| 成人毛片在线| 最近国语视频在线观看免费播放| 国产伦精品一区二区三区视频痴汉| 欧美视频第二页| 日韩免费视频线观看| 黄色手机在线视频| 美女写真理伦片在线看| 日漫免费在线观看网站| 国产精品亚洲一区二区三区妖精| 欧美性极品videosbest| 亚洲精品粉嫩美女一区| 97婷婷大伊香蕉精品视频| 91免费视频播放| 精品裸体bbb| 成人中文字幕电影| 精品国产露脸精彩对白| 成人a免费视频| 亚洲国产精品成人综合色在线婷婷| 又色又爽又黄视频| 日韩一区二区高清| 欧美一级生活片| 亚洲小视频网站| 精品国产精品久久一区免费式| 免费国偷自产拍精品视频| 国产极品在线视频| 日本欧美大码aⅴ在线播放| 91麻豆天美传媒在线| 久久裸体网站| а√最新版地址在线天堂| 啊啊啊啊啊好爽| 成人欧美一区二区| 欧美精品首页| 欧美成人精品不卡视频在线观看| 亚洲国产91视频| 日本欧美一区二区三区不卡视频| 亚洲欧洲闷骚av少妇影院| 成人免费xxxxx在线视频| 欧美高清xxxxxkkkkk| 欧美这里有精品| 日韩精品一区二区三区第95| 国产精品午夜影院| 男女午夜激情视频| 自拍偷拍亚洲天堂| 日本高清不卡一区二区三区视频| 欧美激情欧美| 懂色av中文字幕| 欧美一区二区三区系列电影| 国产精品ⅴa在线观看h| 中文字幕亚洲无线码在线一区| 国产一区二区三区四| www.激情| 亚洲精品欧美日韩| 欧美性生活一区| 青青伊人久久| 国产午夜精品久久久久| 免费黄色小视频在线观看| 男人精品网站一区二区三区| 毛片免费不卡| 美女扒开尿口让男人操亚洲视频网站| 国产美女被遭强高潮免费网站| 国产三级一区| 色噜噜狠狠一区二区三区狼国成人| 亚洲欧洲日本一区二区三区| 97人妻精品一区二区三区| 久久99这里只有精品| 国产69精品久久久久9| 中文字幕在线视频不卡| 欧美精品久久久久久久免费观看| 牛牛电影国产一区二区| 天天做天天爱夜夜爽| 亚洲午夜精品久久久久久性色| 国产欧美日韩视频一区二区三区| 日韩精选在线| 欧美人xxxxx| 三上悠亚av一区二区三区| 亚洲av成人片色在线观看高潮| 欧美丝袜一区二区| 欧美日韩视频免费播放| 中文字幕视频一区二区| 国产精彩视频一区二区| 性欧美疯狂猛交69hd| 性欧美13一14内谢| 2019中文在线观看| 91成人在线精品| 欧美久久一区| 亚洲在线资源| 精品国产aⅴ| 668精品在线视频| 亚洲精品影院在线观看| 91蜜桃传媒精品久久久一区二区| 色噜噜在线网| 大胆亚洲人体视频| 香蕉久久视频| 97免费观看视频| 国产欧美综合精品一区二区| 91精品国产欧美一区二区18| 人妻精油按摩bd高清中文字幕| 国产探花视频在线播放| 国产精一品亚洲二区在线视频| 欧美性受xxxx黒人xyx性爽| 欧美猛男同性videos| 在线人成动漫视频在线观看| 91精彩视频在线观看| 久久久久久久电影一区| 激情综合丁香| 妞干网在线观看视频| 亚洲欧美综合7777色婷婷| 韩国无码av片在线观看网站| 黄色一级视频片| 天天爱天天做天天操| 日韩精品一区二区三区免费观看| 欧美专区第一页| 成人欧美一区二区三区黑人免费| 自拍偷拍亚洲一区| 亚洲国产剧情在线观看| 精品久久久久久久久久久久包黑料| 一级α片免费看刺激高潮视频| 国产精品福利电影| 人妻互换免费中文字幕| 青娱乐在线免费视频| 91精品电影| 欧美 日韩 国产 成人 在线 91| 宅男深夜免费观看视频| 成人啪啪免费看| 在线播放日韩专区| 日本aⅴ精品一区二区三区| 糖心vlog精品一区二区| 亚洲性感美女99在线| 青草av在线| 国产成人精品福利| 精品久久久久一区二区| 欧美一卡2卡3卡4卡无卡免费观看水多多| 一级全黄少妇性色生活片| 国产又粗又猛视频免费| 国产精品欧美亚洲| 日韩三级电影视频| 91精品在线观| 未来日记在线观看| 国产欧美婷婷中文| 99青春婷婷视频| japanese中文字幕| 7m精品福利视频导航| 日本xxxxxx| 9.1在线观看免费| 亚洲成人在线播放| 91精品一区二区| 欧美日韩精品一区二区三区在线观看| 侵犯稚嫩小箩莉h文系列小说| 久热精品视频在线观看一区| av不卡高清| 亚洲美女在线看| 精品国产区一区| 国产精品久久久久久人| 人妻激情另类乱人伦人妻| 精品国产综合区久久久久久| 欧美成人明星100排名| 亚洲国产日韩一级| 洋洋av久久久久久久一区| 成网站在线观看人免费| 久久久久久国产精品日本| 91精品视频专区| 黄色小视频免费| 国产传媒国产传媒| 国产资源精品在线观看| 国产精品免费免费| 天堂网在线最新版www中文网| 韩国一区二区三区在线观看| 欧美激情欧美激情在线五月| 97精品视频在线播放| 久久精品免费播放| 久久精品99久久无色码中文字幕| 黄色三级视频片| 中文字幕日本精品| av中文字幕不卡| 永久免费看mv网站入口亚洲| 91九色在线播放| 亚洲成成品网站| 国产主播精品| 成人短视频在线观看| 在线精品国产成人综合| 91精品国产高清一区二区三密臀| 久久99视频精品| 国产酒店精品激情| 久久久精品在线| 亚洲一区二区欧美| 亚洲国产欧美自拍| 日本三级片在线观看| 国产免费一区二区三区四在线播放| 夜夜嗨aⅴ一区二区三区| 性爱视频在线播放| 亚洲成人精品在线观看| 日本一区二区三区精品视频| 欧美日本国产视频| 在线观看免费播放网址成人| 亚洲欧洲av一区二区三区久久| 日韩中文字幕国产精品| 亚洲精品一区三区三区在线观看| 一区不卡在线观看| 97在线中文字幕| 日韩精品一二区| 欧美色婷婷天堂网站| 无码一区二区精品| 阿v天堂2018| 久久久久久久久爱| 欧美不卡在线播放| 在线影音av| 国产喷水福利在线视频| 手机免费看av网站| 亚洲人成色777777精品音频| 欧美6一10sex性hd| 久久精品欧美视频| 丝袜亚洲精品中文字幕一区| 91精品国产自产| 黑丝美女一区二区| 女人被狂躁到高潮的免费| 久久无码高潮喷水| 国产在线精品一区二区夜色| 在线免费看av的网站| 青青草国产在线播放| 日韩在线视频网站| 欧美一级电影网站| 99re91这里只有精品| 亚洲精品国产suv一区| 成年人视频在线免费| 久久久国产一区二区| 国产精品第13页| 高清不卡一区二区三区| 国产一区二区三区美女| 精品动漫3d一区二区三区免费版| 国产精品三级网站| 成人区精品一区二区婷婷| 久久另类ts人妖一区二区| 91福利小视频| 亚洲色图欧美| 日韩国产成人| 国产男女裸体做爰爽爽| 成人综合视频在线|