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哪一个效力高的细致内容,更多请关注ki4网别的相干文章!