免费注册 查看新帖 |

Chinaunix

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

如何为这个SQL建索引 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-10-31 10:53 |只看该作者 |倒序浏览
select first 20 ringType,
count(distinct ringIndex) as totalRingCount,
sum(downCount) as totalDownCount
from XXX
where countday between '20060915' and '20061015'
group by ringType
order by totalRingCount desc;

想对这个SQL通过建立索引来提高返回速度,可是结果不太理想。
如果是你的话,会建立什么样的索引来优化这条SQL呢?
谢谢:)

论坛徽章:
0
2 [报告]
发表于 2006-10-31 11:48 |只看该作者
countday 建个吧

论坛徽章:
0
3 [报告]
发表于 2006-10-31 17:47 |只看该作者
实际上在countday和ringtype上建了联合索引。但是发现在select的时候磁盘的吞吐量上不去,耗时很多:(

论坛徽章:
0
4 [报告]
发表于 2006-10-31 23:19 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
5 [报告]
发表于 2006-11-01 09:48 |只看该作者
原帖由 czw1413_cn 于 2006-10-31 23:19 发表
如果where 后面就一个countday 条件的话,在countday 上创建索引就可以了
如果还是不理想的话,建议先把数据into到临时表中,然后再选,再ORDER BY 可能会快点

这个查询每次都可能会因为日期条件不同而不同,如果临时表只能使用一次的话,我觉得最好不用,因为其实对于group 或order by,informix在处理时都会自动建立临时表的。。。

论坛徽章:
0
6 [报告]
发表于 2006-11-02 13:05 |只看该作者
ringType 单独建索引
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP