使用union和in哪个效率高
程序员文章站
2022-04-16 19:29:51
...
一直都认为是in的效率要高,但是这次确有点蒙圈。
SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);
这个查询的效率是,经常是1秒多。
mysql> SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);
106 rows in set (1.20 sec)
替换成下面这种写法之后,
SELECT * FROM runinfo WHERE status = 0 union SELECT * FROM runinfo WHERE status = 1 union SELECT * FROM runinfo WHERE status = 2 union SELECT * FROM runinfo WHERE status = 3 union SELECT * FROM runinfo WHERE status = 4 union SELECT * FROM runinfo WHERE status = 7 union SELECT * FROM runinfo WHERE status = 9 union SELECT * FROM runinfo WHERE status = 10
效率有很大的提升。
mysql> 108 rows in set (0.02 sec)
具体的原因我也说不上来,其中status字段有建索引,这个字段会有一些更新。
先做记录,慢慢再搞清楚这件事情吧。
以上就是使用union和in哪个效率高的详细内容,更多请关注其它相关文章!
上一篇: php中静态类与静态变量用法的思路分析
下一篇: mysql如何添加多个btree索引
推荐阅读
-
sqlserver Union和SQL Union All使用方法
-
MySQL中union和order by同时使用的实现方法
-
sqlserver Union和SQL Union All使用方法
-
MySQL中union和order by同时使用的实现方法
-
sqlserver Union和SQL Union All使用方法
-
Edge浏览器和IE浏览器哪个好用?使用Win10浏览器的五大理由
-
Edge浏览器和IE浏览器哪个好用?使用Win10浏览器的五大理由
-
sql 中 并集union和union all的使用区别
-
小狗吸尘器和莱克哪个好(两大品牌使用评测对比告诉你)
-
SQL数据库表union和unionall的使用和介绍