免费注册 查看新帖 |

Chinaunix

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

这个sql如何优化date>='2009-1-1' and date<'2010-5-1' 是否需要 改写 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2010-04-15 14:36 |只看该作者 |倒序浏览
这个sql如何优化

select * from a where type=? and date>='2009-1-1' and date<'2010-5-1' and t.status in (1,2,3,4,5,6..)

1 date>='2009-1-1' and date<'2010-5-1' 是否需要 改写为between ('2009-1-1','2010-5-1')
2 status 是否必须单独建立一个只有该字段的索引 当前在线表已经有索引(Type`,`status`)

(附后
explain
select * from a where type=? and date>='2009-1-1' and date<'2010-5-1' and t.status in (1,2,3,4,5,6..)

-------+-------+-------------+
| id | select_type | table | type | possible_keys | key | key_len | ref | rows | Extra |
+----+-------------+-------+------+--------------------------------------------------------------------------------+--------------------------+---------+-------+-------+-------------+
| 1 | SIMPLE | t | ref | idx_TE_sate,idx_TEnTypePard,idx_TE_d_tt_status | idx_TE__tt_status | 4 | const | 27563 | Using where |
+----+-------------+-------+------+--------------------------------------------------------------------------------+--------------------------+---------+-------+-------+-------------+
1 row in set

可以看到他实际是走 索引(Type`,`status`) , 可以key_len=4| ref=const  

论坛徽章:
0
2 [报告]
发表于 2010-04-16 23:35 |只看该作者
不太清楚表结构,查询只走了 (TYPE,STATUS)的索引,出结果后才用WHERE 语句去过滤DATE, 首先考虑扩展 (TYPE,STATUS)的索引,其次才考虑加单独的索引。

论坛徽章:
9
每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00每日论坛发贴之星
日期:2016-01-04 06:20:00数据库技术版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00IT运维版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00综合交流区版块每日发帖之星
日期:2016-01-04 06:20:00数据库技术版块每周发帖之星
日期:2016-03-07 16:30:25
3 [报告]
发表于 2010-04-17 19:42 |只看该作者
1. date>='2009-1-1' and date<'2010-5-1'  和 between ('2009-1-1','2010-5-1') 对于优化器来说是等价的。
2. 从 key_len=4 来看(`Type`,`status`) 只用到了type这一部份。(原因是=和in的结合不能用索引)
建议是做 (type,date)的符合索引。

论坛徽章:
0
4 [报告]
发表于 2010-04-25 14:43 |只看该作者
还有地方优化,就是把时间类型存为int型

论坛徽章:
0
5 [报告]
发表于 2010-05-11 11:50 |只看该作者
想办法减少你的ROWS SCAN的个数。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP