海量数据库查询优化及分页算法
2008-08-30 09:56:49 来源:WEB开发网(四)其他书上没有的索引使用经验总结
1、用聚合索引比用不是聚合索引的主键速度快
下面是实例语句:(都是提取25万条数据)
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenwherefariqi='2004-9-16'
使用时间:3326毫秒
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenwheregid<=250000
使用时间:4470毫秒
这里,用聚合索引比用不是聚合索引的主键速度快了近1/4。
2、用聚合索引比用一般的主键作order by时速度快,特别是在小数据量情况下
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenorderbyfariqi
用时:12936
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenorderbygid
用时:18843
这里,用聚合索引比用一般的主键作order by时,速度快了3/10。事实上,如果数据量很小的话,用聚集索引作为排序列要比使用非聚集索引速度快得明显的多;而数据量如果很大的话,如10万以上,则二者的速度差别不明显。
3、使用聚合索引内的时间段,搜索时间会按数据占整个数据表的百分比成比例减少,而无论聚合索引使用了多少个
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenwherefariqi>'2004-1-1'
用时:6343毫秒(提取100万条)
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenwherefariqi>'2004-6-6'
用时:3170毫秒(提取50万条)
selectgid,fariqi,neibuyonghu,reader,titlefromTgongwenwherefariqi='2004-9-16'
用时:3326毫秒(和上句的结果一模一样。如果采集的数量一样,那么用大于号和等于号是一样的)
更多精彩
赞助商链接