使用union和in哪个效率高


本文摘自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中unionunion all的用法

sql语句的minus,intersect和union all的解析

更多相关阅读请进入《union》频道 >>


数据库系统概念 第6版
书籍

数据库系统概念 第6版

机械工业出版社

本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。



打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...