2017計算機等考三級數(shù)據(jù)庫輔導:其他書上沒有的索引使用經(jīng)驗總結(jié)

字號:


    (四)其他書上沒有的索引使用經(jīng)驗總結(jié)
    1、用聚合索引比用不是聚合索引的主鍵速度快
    下面是實例語句:(都是提取25萬條數(shù)據(jù))
    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時速度快,特別是在小數(shù)據(jù)量情況下
    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。事實上,如果數(shù)據(jù)量很小的話,用聚集索引作為排序列要比使用非聚集索引速度快得明顯的多;而數(shù)據(jù)量如果很大的話,如10萬以上,則二者的速度差別不明顯。
    3、使用聚合索引內(nèi)的時間段,搜索時間會按數(shù)據(jù)占整個數(shù)據(jù)表的百分比成比例減少,而無論聚合索引使用了多少個
    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毫秒(和上句的結(jié)果一模一樣。如果采集的數(shù)量一樣,那么用大于號和等于號是一樣的)
    select gid,fariqi,neibuyonghu,reader,title from Tgongwen where fariqi>'2004-1-1' and fariqi<'2004-6-6'
    用時:3280毫秒
    4 、日期列不會因為有分秒的輸入而減慢查詢速度
    下面的例子中,共有100萬條數(shù)據(jù),2004年1月1日以后的數(shù)據(jù)有50萬條,但只有兩個不同的日期,日期精確到日;之前有數(shù)據(jù)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毫秒