明輝手游網(wǎng)中心:是一個免費(fèi)提供流行視頻軟件教程、在線學(xué)習(xí)分享的學(xué)習(xí)平臺!

使用union與in哪一個效率高

[摘要]一直都認(rèn)為是in的效率要高,但是這次確有點蒙圈。SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);  這個查詢的效率是,經(jīng)常是1秒多。...
一直都認(rèn)為是in的效率要高,但是這次確有點蒙圈。


SELECT * FROM runinfo WHERE status in (0,2,1,3,4,7,9,10);  

這個查詢的效率是,經(jīng)常是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哪個效率高的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!


學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。