本文摘自PHP中文网,作者一个新手,侵删。
一直都认为是in的效率要高,但是这次确有点蒙圈。
1 | SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);
|
这个查询的效率是,经常是1秒多。
1 | mysql> SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);
|
106 rows in set (1.20 sec)
替换成下面这种写法之后,
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | 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
|
效率有很大的提升。
1 2 | mysql>
108 rows in set (0.02 sec)
|
具体的原因我也说不上来,其中status字段有建索引,这个字段会有一些更新。
先做记录,慢慢再搞清楚这件事情吧。
以上就是使用union和in哪个效率高的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
union all是什么意思
使用union和in哪个效率高
sql union用法是什么?
mysql中union与union all的用法
sql语句的minus,intersect和union all的解析
更多相关阅读请进入《union》频道 >>
机械工业出版社
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。
转载请注明出处:木庄网络博客 » 使用union和in哪个效率高