zoukankan      html  css  js  c++  java
  • 在MongoDB中创建一个索引而性能提升1000倍的小例子

    https://www.cnblogs.com/xuliuzai/p/9965229.html的博文中我们介绍了MongoDB的常见索引的创建语法。部分同学还想看看MongoDB的威力到底有多大,所以,在这儿追加一个例子,感受一下索引的性能。

    通过在某一字段上创建索引,从优化前的执行15.15S到优化后降至0.013S,性能提升了1000多倍。

    此为实际生产中的一个真实案例,我们有一个集合QQStatements,其数据量为2604W,如下图所示。

    系统需要查询此表最近的变动情况,即需要抓取新增数据量和修改的数据量。

    查询语句如下:

    db.QQStatements.find({
        $or:
        [
            {Rec_CreateTime:{$gt: ISODate("2019-01-07 16")}}
            ,{Rec_ModifyTime:{$gt: ISODate("2019-01-07 16")}}
            ]
        
    } )

    但此查询语句不理想,有时耗时25S,多次执行有缓存后也要15S左右,如下图:

    查看此表,发现Rec_CreateTime字段建有索引,单独执行符合Rec_CreateTime 条件的语句,很快 0.1 S 内就执行完成。

    而Rec_ModifyTime字段没有索引,单独执行符合Rec_ModifyTime条件的语句较慢,需要15S左右。

    到这儿,就可以判读出问题是缺失索引,和开发同学确认后,此场景时常用,此字段需要添加索引。

    执行添加索引的命令:

    db.QQStatements.createIndex({"Rec_ModifyTime":1},{"name":'idx_Rec_ModifyTime',background:true})

     Rec_ModifyTime字段添加索引后,整个语句执行降至0.013S(20S-->0.02S )

     从上面可以看出在MongoDB数据库中索引很有必要,性能可以优化数百倍。

     本文版权归作者所有,未经作者同意不得转载,谢谢配合!!!

  • 相关阅读:
    HDU 1224 无环有向最长路
    HDU 1220 简单数学题
    HDU 1203 背包问题
    HDU 1176 DP
    HDU 1159 LCS最长公共子序列
    HDU 1160 排序或者通过最短路两种方法解决
    hdu 2349 最小生成树
    次小生成树的学习
    最小生成树prime算法模板
    poj 1679 判断最小生成树是否唯一
  • 原文地址:https://www.cnblogs.com/xuliuzai/p/10252785.html
Copyright © 2011-2022 走看看