使用union和in哪个效率高

一直都认为是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. SELECT * FROM runinfo WHERE status = 0unionSELECT * FROM runinfo WHERE status = 1unionSELECT * FROM runinfo WHERE status = 2unionSELECT * FROM runinfo WHERE status = 3unionSELECT * FROM runinfo WHERE status = 4unionSELECT * FROM runinfo WHERE status = 7unionSELECT * FROM runinfo WHERE status = 9unionSELECT * FROM runinfo WHERE status = 10  

登录后复制

效率有很大的提升。

  1. mysql>108 rows in set (0.02 sec)

登录后复制

 具体的原因我也说不上来,其中status字段有建索引,这个字段会有一些更新。

先做记录,慢慢再搞清楚这件事情吧。

以上就是使用union和in哪个效率高的详细内容,更多请关注【创想鸟】其它相关文章!

声明:本站所有文章,如无特殊说明或标注,均为本站原创发布。任何个人或组织,在未征得本站同意时,禁止复制、盗用、采集、发布本站内容到任何网站、书籍等各类媒体平台。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。
数据库

如何建立可打印中文的数据库

2025-2-21 12:04:18

数据库

mySQL用代码添加表格内容和删除数据方法

2025-2-21 12:04:36

0 条回复 A文章作者 M管理员
欢迎您,新朋友,感谢参与互动!
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
私信列表
搜索