日期:2014-05-16 浏览次数:20488 次
?
索引的 命令
创建索引 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> 这是个内部的存储,不能进行查询。 |
?