百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

MySQL in 和 exists 的使用区别

yuyutoo 2024-11-17 17:53 2 浏览 0 评论

在MySQL中,IN和EXISTS都是用于检查某个值是否在一个集合中,在大多数情况下是可以互换使用。但他们在使用时,还是存在些许差异的,它们的主要区别体现在性能和语义上。

性能上的区别

IN:当我们知道从哪个列表中查找值时,可以使用IN。IN操作符允许你在特定列中查找多个值。

SELECT * FROM table_name WHERE column_name IN (x1, x1, ...);

EXISTS:当我们想要确认某个子查询是否至少返回一个行时,可以使用EXISTS。EXISTS是一个布尔操作符,用于测试子查询是否返回。

SELECT * FROM table_name WHERE EXISTS (subquery);

在性能方面,EXISTS通常比IN更快,因为EXISTS操作符一旦找到满足条件的记录就会停止搜索,而IN操作符会搜索整个列表。在某些情况下,IN可能比EXISTS具有更好的性能:

  1. 当子查询返回的结果集很小,而主查询返回的结果集很大时,IN一般会比EXISTS更快。这是因为IN操作符首先会执行子查询并将结果存储在一个临时表中,然后MySQL会对这个临时表进行优化,并在主查询中使用这个优化过的临时表。如果子查询返回的结果集很小,那么这个优化过程可能会非常快。
  2. 当子查询的结果集不包含NULL值时,IN可能会比EXISTS更快。这是因为当子查询的结果集包含NULL值时,IN操作符需要进行额外的处理,而EXISTS操作符则不需要。

上面只是常规统计结果,在实际的查询优化中,还是需要根据具体情况(例如,数据表的数据分布,索引设计,硬件配置等)来选择最适合的查询方式。

语义上的区别

IN 和 EXISTS 除了在性能上的区别,在结果集的处理上也有区别,主要针对null值的处理,这个会导致两个查询得到的结果集有差异,下面进行举例说明。

建表、初始化数据:

create table t1(id int primary key, name varchar(10));
create table t2(id int primary key, name varchar(10));
insert into t1 values(1,'a'), (2,'b'), (3,null);
insert into t2 values(1,'a'), (2,'c'), (3,null);

上面语句,我们创建了两张表t1和t2,并分别初始化了3条数据,我们接下来执行下面SQL语句会:

mysql> select * from t1 where t1.name in (select name from t2);
+----+------+
| id    | name |
+----+------+
|  1    | a        |
+----+------+
1 row in set (0.01 sec)

mysql> select * from t1 where exists (select 1 from t2 where t2.name=t1.name);
+----+------+
| id    | name |
+----+------+
|  1    | a        |
+----+------+
1 row in set (0.00 sec)

mysql> select * from t1 where t1.name not in (select name from t2);
Empty set (0.01 sec)

mysql> select * from t1 where not exists (select 1 from t2 where t2.name=t1.name);
+----+------+
| id    | name |
+----+------+
|  2    | b        |
|  3    | NULL |
+----+------+
2 rows in set (0.00 sec)

从上面结果可以看出,NOT IN 和 NOT EXISTS 返回的结果集不一样,为什么not in结果会返回为空了?这里主要是因为 IN 和 EXISTS 针对 null 的处理方式不一样,NOT IN等价于下面的SQL语句,因为t1.name!=null永远不成立,所以最终结果集返回为空。

mysql> select * from t1 where t1.name!='a' and t1.name!='c' and t1.name!=null;
Empty set (0.00 sec)

下面SQL执行结果同NOT EXISTS

mysql> select * from t1 where t1.name not in (select t2.name from t2 where t2.name is not null) or t1.name is null;
+----+------+
| id    | name |
+----+------+
|  2    | b        |
|  3    | NULL |
+----+------+
2 rows in set (0.00 sec)

通过上面的例子可以直观的看出,in和exists针对null的处理方式不一样会导致结果集有差异,在使用过程中需要格外注意。

相关推荐

史上最全的浏览器兼容性问题和解决方案

微信ID:WEB_wysj(点击关注)◎◎◎◎◎◎◎◎◎一┳═┻︻▄(页底留言开放,欢迎来吐槽)●●●...

平面设计基础知识_平面设计基础知识实验收获与总结
平面设计基础知识_平面设计基础知识实验收获与总结

CSS构造颜色,背景与图像1.使用span更好的控制文本中局部区域的文本:文本;2.使用display属性提供区块转变:display:inline(是内联的...

2025-02-21 16:01 yuyutoo

写作排版简单三步就行-工具篇_作文排版模板

和我们工作中日常word排版内部交流不同,这篇教程介绍的写作排版主要是用于“微信公众号、头条号”网络展示。写作展现的是我的思考,排版是让写作在网格上更好地展现。在写作上花费时间是有累积复利优势的,在排...

写一个2048的游戏_2048小游戏功能实现

1.创建HTML文件1.打开一个文本编辑器,例如Notepad++、SublimeText、VisualStudioCode等。2.将以下HTML代码复制并粘贴到文本编辑器中:html...

今天你穿“短袖”了吗?青岛最高23℃!接下来几天气温更刺激……

  最近的天气暖和得让很多小伙伴们喊“热”!!!  昨天的气温到底升得有多高呢?你家有没有榜上有名?...

CSS不规则卡片,纯CSS制作优惠券样式,CSS实现锯齿样式

之前也有写过CSS优惠券样式《CSS3径向渐变实现优惠券波浪造型》,这次再来温习一遍,并且将更为详细的讲解,从布局到具体样式说明,最后定义CSS变量,自定义主题颜色。布局...

柠檬科技肖勃飞:大数据风控助力信用社会建设

...

你的自我界限够强大吗?_你的自我界限够强大吗英文

我的结果:A、该设立新的界限...

行内元素与块级元素,以及区别_行内元素和块级元素有什么区别?

行内元素与块级元素首先,CSS规范规定,每个元素都有display属性,确定该元素的类型,每个元素都有默认的display值,分别为块级(block)、行内(inline)。块级元素:(以下列举比较常...

让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华
让“成都速度”跑得潇潇洒洒,地上地下共享轨交繁华

去年的两会期间,习近平总书记在参加人大会议四川代表团审议时,对治蜀兴川提出了明确要求,指明了前行方向,并带来了“祝四川人民的生活越来越安逸”的美好祝福。又是一年...

2025-02-21 16:00 yuyutoo

今年国家综合性消防救援队伍计划招录消防员15000名

记者24日从应急管理部获悉,国家综合性消防救援队伍2023年消防员招录工作已正式启动。今年共计划招录消防员15000名,其中高校应届毕业生5000名、退役士兵5000名、社会青年5000名。本次招录的...

一起盘点最新 Chrome v133 的5大主流特性 ?

1.CSS的高级attr()方法CSSattr()函数是CSSLevel5中用于检索DOM元素的属性值并将其用于CSS属性值,类似于var()函数替换自定义属性值的方式。...

竞走团体世锦赛5月太仓举行 世界冠军杨家玉担任形象大使

style="text-align:center;"data-mce-style="text-align:...

学物理能做什么?_学物理能做什么 卢昌海

作者:曹则贤中国科学院物理研究所原标题:《物理学:ASourceofPowerforMan》在2006年中央电视台《对话》栏目的某期节目中,主持人问过我一个的问题:“学物理的人,如果日后不...

你不知道的关于这只眯眼兔的6个小秘密
你不知道的关于这只眯眼兔的6个小秘密

在你们忙着给熊本君做表情包的时候,要知道,最先在网络上引起轰动的可是这只脸上只有两条缝的兔子——兔斯基。今年,它更是迎来了自己的10岁生日。①关于德艺双馨“老艺...

2025-02-21 16:00 yuyutoo

取消回复欢迎 发表评论: