免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12
最近访问板块 发新帖
楼主: 龙雪刚
打印 上一主题 下一主题

非常奇怪的 count(*) [复制链接]

论坛徽章:
0
11 [报告]
发表于 2012-01-18 16:47 |只看该作者
大家有时间可以在自己本机试下,我测试了5.0.27,与5.5.15这两个版本,explain都是一样的。这种情况似乎相当诡异。

论坛徽章:
0
12 [报告]
发表于 2012-01-19 11:01 |只看该作者
当你发现所有的版本都这样,他就不诡异了,我找了很多地方,也没有发现有讲这个的,只能说优化器就是这么选择的。毕竟是不排序,查找二级索引肯定是快的。

论坛徽章:
0
13 [报告]
发表于 2012-01-19 15:57 |只看该作者
using index是覆盖索引的意思

论坛徽章:
2
摩羯座
日期:2014-05-29 17:38:40数据库技术版块每日发帖之星
日期:2016-08-05 06:20:00
14 [报告]
发表于 2012-01-19 16:46 |只看该作者
楼主,你试试,不用count(*),也会走组合索引
SELECT C2 FROM TABLE WHERE C2 > ?

论坛徽章:
4
CU大牛徽章
日期:2013-03-13 15:32:35CU大牛徽章
日期:2013-03-13 15:38:15CU大牛徽章
日期:2013-03-13 15:38:52戌狗
日期:2013-12-27 15:08:11
15 [报告]
发表于 2012-01-31 11:10 |只看该作者
看是否是count(*)的原因
用count(c2)查询试下

论坛徽章:
0
16 [报告]
发表于 2012-02-02 14:16 |只看该作者
mark一下:type列:index,按索引次序的全表扫描;ref,这个才是索引访问,返回所有匹配某个单独值的行。
           extra列:using index:使用覆盖索引
覆盖索引是指当索引项包含了所有需要的信息,这时只需要访问索引就能得到需要的数据,而不需再访问数据页。
select c2 from where c2> ..   和select count(*) from where c2 > ..  都使用了覆盖索引,select c3 from where c2 没有使用覆盖索引。

您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP