- 博客(1)
- 收藏
- 关注
转载 Mysql in和exist
假设 a表1000000数据,b表100数据,这里有两个过程,b 表数据最少,查询引擎优化选择b为驱动表,循环b表的100条数据,跟a表的1000000数据去匹配,这个匹配的过程是B+树的查找过程,比循环取数要快的多。小表驱动大表,in后面跟的是小表,exists后面跟的是大表。可以这么理解:in后面跟的是小表,exists后面跟的是大表。当A表的数据集小于B表的数据集时,用exists优于in。当B表的数据集小于A表数据集时,用in优于exists。需要注意的是a表字段id和b表字段id 都要建立索引。
2023-05-18 11:06:10 105 1
空空如也
空空如也
TA创建的收藏夹 TA关注的收藏夹
TA关注的人