**

    • 索引基础

    索引是对数据库表中一列或多列的值进行排序的一种结构,可以让我们查询数据库变得 更快。MongoDB 的索引几乎与传统的关系型数据库一模一样,这其中也包括一些基本的查 询优化技巧
    可以通过以下命令来创建索引,name表示索引字段,1表示正序,-1表示逆序
    db.admin.ensureIndex({name: 1})

    以下命令可以查看当前集合的索引
    db.admin.getIndexes()

    以下命令可以删除索引
    db.admin.dropIndex({name: 1})

    再monngoDb中,我们也可以创建复合索引
    db.admin.ensureIndex({name: 1, age: -1})
    该索引被创建后,基于 name 和 age 的查询将会用到该索引,或者是基于 name 的查询也会用到该索引,但是只是基于 age 的查询将不会用到该复合索引。因此可以说, 如果想用到复合索引,必须在查询条件中包含复合索引中的前 N 个索引列。然而如果查询 条件中的键值顺序和复合索引中的创建顺序不一致的话,MongoDB 可以智能的帮助我们调 整该顺序,以便使复合索引可以为查询所用。如:
    db.admin.find({"age": 30, "name": "dell"})

    对于上面示例中的查询条件,MongoDB 在检索之前将会动态的调整查询条件文档的顺 序,以使该查询可以用到刚刚创建的复合索引。
    上面创建的索引,MongoDB 都会根据索引的 字段名和索引方向为新创建的索引 自动分配一个索引名如:name_1,我们可以在创建索引时为其指定索引名,如:
    db.admin.ensureIndex({"name":1},{"name":"name"})

    • 唯一索引

      1. 所谓唯一索引,就是指当设置未唯一索引后,这个字段的数据不能有重复,例如name为唯一字段,则该集合中的数据不能出现两个name相同的文档<br />创建唯一索引命令式如下:<br />`db.admin.ensureIndex({name: 1}, {unique: true})`

    此时如果插入相同的文档,mongoDB将会报错如:
    db.admin.insert({name: admin})
    db.admin.insert({name: admin})

    同理,我们也可以创建复合唯一索引
    db.admin.ensureIndex({name: 1, age: -1}, {unique: true})

    • 索引的参数

    image.png
    如果在为已有数据的文档创建索引时,可以执行下面的命令,以使 MongoDB 在后台创 建索引,这样的创建时就不会阻塞其他操作。但是相比而言,以阻塞方式创建索引,会使整 个创建过程效率更高,但是在创建时 MongoDB 将无法接收其他的操作。
    db.user.ensureIndex({"username":1},{"background":true})

    • explain的使用

    explain 方法可以帮助你获得查询方面诸多有用的信息。调用explan方法,就可以得到查询细节。如下
    image.png
    explain携带参数executionStats可以得到查询时间,如
    db.admin.find({name: "admin13"}).explain("executionStats")
    image.png