使用union和in哪个效率高
程序员文章站
2022-03-24 21:14:22
...
一直都认为是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哪个效率高的详细内容,更多请关注其它相关文章!
上一篇: Magento报错之SQLSTATE[23000]:
下一篇: Oracle数据库的后备和恢复
推荐阅读
-
Edge浏览器和IE浏览器哪个好用?使用Win10浏览器的五大理由
-
sql 中 并集union和union all的使用区别
-
小狗吸尘器和莱克哪个好(两大品牌使用评测对比告诉你)
-
SQL数据库表union和unionall的使用和介绍
-
同时使用Union和Order by问题(ORA-00933错误)解决
-
sql Union和Union All的使用方法
-
卸妆油和卸妆水哪个好 卸妆水使用方法与和注意事项
-
SQL中UNION ALL 和UNION的区别及使用
-
游戏本和轻薄本哪个更适合办公人群使用?
-
使用thikphp框架的,一个项目里面有多个文件夹,html页面放在哪个文件夹里,和Action文件夹里的方法怎么调用,特别是在调用时的路径有关问题,尽量详细