51Testing软件测试论坛

 找回密码
 (注-册)加入51Testing

QQ登录

只需一步,快速开始

微信登录,快人一步

查看: 5911|回复: 0
打印 上一主题 下一主题

用聚合索引的速度分析

[复制链接]

该用户从未签到

跳转到指定楼层
1#
发表于 2007-9-11 18:28:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
1、用聚合索引比用不是聚合索引的主键速度快
  下面是实例语句:(都是提取25万条数据)

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi=''2004-9-16''

  
使用时间:3326毫秒

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen where gid<=250000

  
使用时间:4470毫秒

  这里,用聚合索引比用不是聚合索引的主键速度快了近1/4。

  2、用聚合索引比用一般的主键作order by时速度快,特别是在小数据量情况下

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen order by fariqi

  
用时:12936毫秒

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen order by gid

  
用时:18843毫秒

  这里,用聚合索引比用一般的主键作order by时,速度快了3/10。事实上,如果数据量很小的话,用聚集索引作为排序列要比使用非聚集索引速度快得明显的多;而数据量如果很大的话,如10万以上,则二者的速度差别不明显。

  3、使用聚合索引内的时间段,搜索时间会按数据占整个数据表的百分比成比例减少,而无论聚合索引使用了多少个:

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>''2004-1-1''

  
用时:6343毫秒(提取100万条)

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>''2004-6-6''

  
用时:3170毫秒(提取50万条)

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi=''2004-9-16''

  
用时:3326毫秒(和上句的结果一模一样。如果采集的数量一样,那么用大于号和等于号是一样的)

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen
            where fariqi>''2004-1-1'' and fariqi<''2004-6-6''

  
用时:3280毫秒

  4、日期列不会因为有分秒的输入而减慢查询速度

  下面的例子中,共有100万条数据,2004年1月1日以后的数据有50万条,但只有两个不同的日期,日期精确到日;之前有数据50万条,有5000个不同的日期,日期精确到秒。

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen
               where fariqi>''2004-1-1'' order by fariqi

  
用时:6390毫秒

       select gid,fariqi,neibuyonghu,reader,title from Tgongwen
            where fariqi<''2004-1-1'' order by fariqi

  
用时:6453毫秒
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏
回复

使用道具 举报

本版积分规则

关闭

站长推荐上一条 /1 下一条

小黑屋|手机版|Archiver|51Testing软件测试网 ( 沪ICP备05003035号 关于我们

GMT+8, 2024-4-27 01:04 , Processed in 0.071938 second(s), 27 queries .

Powered by Discuz! X3.2

© 2001-2024 Comsenz Inc.

快速回复 返回顶部 返回列表