`
风雪涟漪
  • 浏览: 508773 次
  • 性别: Icon_minigender_1
  • 来自: 大连->北京
博客专栏
952ab666-b589-3ca9-8be6-3772bb8d36d4
搜索引擎基础(Search...
浏览量:9069
Ae468720-c1b2-3218-bad0-65e2f3d5477e
SEO策略
浏览量:18487
社区版块
存档分类
最新评论

MongoDB 索引的命令 Index-Related Commands

阅读更多

 

索引的 命令

创建索引

ensureIndex()  是创建索引便捷方法。 它的实现其实就是创建一个索引添加到system.indexes这个collection中。

> use test
> db.myCollection.ensureIndex(<keypattern>);
> // same as:
> db.system.indexes.insert({ name: "name", ns: "namespaceToIndex",     key: <keypattern> });

注意: 一旦你创建了索引,所有插入collection的document像已存在的doucment一样会被索引。如果collection非常大,创建索引的时间可能会非常长并且会阻塞其他的操作。然而1.32版本,可以在后台执行这个过程。具体看如下连接 background indexing docs  。

你可以查询system.indexes来查看当前db test的collection上的索引。

  >db.system.indexes.find( { ns: "test.foo" } );

一些驱动,如果最近调用过ensureIndex(),它会进行记录并且不会执行这个插入操作。In some drivers,  ensureIndex()  remembers if it has recently been called, and foregoes the insert operation in that case. ensureIndex是个轻量的操作 ,因此它可以经常被调用,来保证索引的存在。

删除索引

Shell命令

db.mycollection.dropIndex(<name_or_pattern>)
db.mycollection.dropIndexes()
// example:t.dropIndex( { name : 1 } );

驱动

{ deleteIndexes: <collection_name>, index: <index_name> }
// <index_name>添加通配符*会删除所有的索引,除了_id。

索引的命名空间Index Namespace

每个索引都有自己的命名空间。如下

<collectionnamespace>.$<indexname>

这是个内部的存储,不能进行查询。

 

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics