免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1382 | 回复: 5
打印 上一主题 下一主题

MySQL索引奇怪问题,google上找不到答案啊。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-02-16 16:20 |只看该作者 |倒序浏览
我有一张数据表:
CREATE TABLE `counter110` (
  `date` mediumint(9) NOT NULL default '0',
  `time` tinyint(4) NOT NULL default '0',
  `cgi` int(11) NOT NULL default '0',
  PRIMARY KEY  (`cgi`,`date`,`time`),
  KEY `date` (`date`,`time`)
) ENGINE=MyISAM DEFAULT CHARSET=gbk

存入数据后,约100万条,打explain select * from counter110 where date>=60214 and date<=60216,type是range,key是date,
但是打explain select * from counter110 where date>=60213 and date<=60216,type就变成ALL了,key是null。
同时date取值60211到60213就是对的,但取60210到60213就错了。
为什么会这样啊?我试过修表,优化表,还有use index(date),发现都没有用,难道对整形建索引后,对于>=和<=,的搜索,MYSQL会不确定的使用index?
本机配置PIII600,256M内存,rh9,MYSQL 4.1.14
急盼答复,谢谢。

论坛徽章:
0
2 [报告]
发表于 2006-02-17 08:54 |只看该作者
同时date取值60211到60213就是对的,但取60210到60213就错了。


这句话是什么意思?

论坛徽章:
0
3 [报告]
发表于 2006-02-17 10:38 |只看该作者
就是指取date>=60211 and date<=60213,explain的结果是type(range),而date>=60210 and date<=60213 explain的结果是type(ALL),照理说,只要我设了date这一列索引,不管>=和<=之的范围多大,type应该都是(range)呀,MYSQL怎么会有的搜索范围引用INDEX,有的范围却不引用。

论坛徽章:
0
4 [报告]
发表于 2006-02-17 13:18 |只看该作者
explain只是帮助你分析select可能存在的问题,并不是确切结果,你先ANALYZE 一下你的表,同时说明你的表记录有多少。
上述提到的2次不同查询使用的时间相差多少?

论坛徽章:
0
5 [报告]
发表于 2006-02-18 11:12 |只看该作者
如果你取得的结果集的数量超过你的表总数的1/3,那么就不使用索引,是不是这个原因?

论坛徽章:
0
6 [报告]
发表于 2006-02-18 19:21 |只看该作者
楼上的,能不能具体讲一下?从没听说过嘛。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP