对单一键建立索引

db.collection.createindex(
    {name: 1}
)

在集合的同一个键上不能重复建立单一索引;若已经建立了索引,再在间一个Key 上建立索引,将给予出错提示。

1升序,-1降序


嵌套文档单字段索引

db.books.insert(
    {
        name:"  
  


唯一索引

db.collection.createindex(
    {name: 1},
    {unique: true} //(注意MongoDB的命令是大小写敏感的)
)

name的值必须是唯一的,不能有重复值出现;否则,MongoDB将新插入的重复文档予以拒绝。在没有指定{unique:true}参数选项的情况下,索引方法允许存在宇段值重复的多文档记录。


建立多字段索引(组合/复合索引)

//对两个字段建立索引
db.books.createindex(
    {
        price:l , color:-1
    }
)

//用sort 排序查询
db.books.find({}, {_id: 0}).sort.({price: 1, color: -1})

上述代码先用createIndex命令建立price、color多键组合索引,然后用find()查找文档记录;对查找出来的文档记录结果用sort({price: 1, color:  -1}先用做price 升序排序,在price价格一样的情况下,再对price相同记录做color降序排序


多宇段唯一索引

db.books.createindex({name: l , price: l}, {unique: true}) //是允许的

只要name 和price 组合起来的值保持唯一性


基本文本索引

db.books.createindex({narne: "text"})  //为name 建立文本索引

指定权重文本索引

db.books.createIndex(
    {
        name: "text",
        price: "text"
    },
    {
        weights: {name: 10}, //为name指定索引权重
        name: "TextIndex"    //默认情况下,price权重为1
    }
);


通配符文本索引

为指定集合中的所有字符串内容进行搜索提供通配索引,这在高度非结构化的文档里比较有用

db.books.createIndex({"$**": "text"})


哈希索引

用于支持对分片键(带哈希键值对的分片集合)的分片数据索引,主要用于分布式数据索引

db.collection_name.createIndex({_id: "hashed"})

命令说明:key为含有哈希值的键

(1.hashed 索引不支持多字段索。2.hashed会把浮点数的小数部分自动去掉,所以对浮点数字段进行索引时,要注意该特殊情况。3.hashed 不支持唯一索引)


还可以用ensureIndex()创建索引

>db.collection.ensureIndex({id: "hashed"})

MongoDB 3.0开始用createindex 命令代替ensureIndex


(1)db.collection.droplndex(index):移除集合指定的索引功能。index参数为指定需要删除的集合索引名,可用getlndexes()函数获取集合的所有索引名称。
(2)db.collection.droplndexes():移除一个集合的所有索引功能。
(3)db.collection.getlndexes():返回一个指定集合的现有索引描述信息的文档数组。
(4)db.collection.relndex():删除指定集合上所有索引,并重新构建所有现有索引。在具有大量数据集合的情况下,该操作将大量消耗服务器的运行资源,引起运行性能急剧下降等问题的发生。
(5)db.collection.totallndexSize():提供指定集合索引大小的报告信息。