专注收集记录技术开发学习笔记、技术难点、解决方案
网站信息搜索 >> 请输入关键词:
您当前的位置: 首页 > Go

第四一部分 性能篇 第十章 MongoDB 索引

发布时间:2011-06-29 18:25:30 文章来源:www.iduyao.cn 采编人员:星星草
第四部分 性能篇 第十章 MongoDB 索引

1、简介
MongoDB提供了多样性的索引支持,索引信息被保存在system.indexes中,且默认总是为_id创建索引,它的索引使用基本和MySQL的关系型数据库一样,其实可以这样说说,索引是凌驾于数据存储系统之上的另外一层系统,所以各种结构迥异的存储都有相同或者相似的索引实现及使用接口并不足为奇。

2、基础索引
在字段age上创建索引,1(升序),-1(降序)

<span style="font-family:SimHei;font-size:14px;">db.user.ensureIndex({age:1})
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 1,
        "numIndexesAfter" : 2,
        "ok" : 1
}
> db.user.getIndexes();
[
        {
                "v" : 1,
                "key" : {
                        "_id" : 1
                },
                "name" : "_id_",
                "ns" : "test.user"
        },
        {
                "v" : 1,
                "key" : {
                        "age" : 1
                },
                "name" : "age_1",
                "ns" : "test.user"
        }
]
> 
</span>
说明

上列中显示出来了一共有2个索引,其中_id是创建表的时候自动创建的索引,此索引是不能够被删除的。

当系统已有大量数据时,创建索引的过程是个非常耗时的过程,我们可以在后台执行,只需要制定background:true即可。

>db.user.ensureIndex({age:1},{background:true})


3、文档索引

索引可以任何类型的字段,甚至文档。

<span style="font-family:SimHei;font-size:14px;">> db.factories.insert({name:"www",addr:{city:"BJ",state:"BEIJING"}});
WriteResult({ "nInserted" : 1 })</span>
在addr列上创建索引

<span style="font-family:SimHei;font-size:14px;">> db.factories.ensureIndex({addr:1});
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 1,
        "numIndexesAfter" : 2,
        "ok" : 1
}</span>
下面的查询将会用到我们刚刚创建的索引

<span style="font-family:SimHei;font-size:14px;">> db.factories.find({addr:{city:"BJ",state:"BEIJING"}});
{ "_id" : ObjectId("54a935b579ceadf5fa8e2ec1"), "name" : "www", "addr" : { "city" : "BJ", "state" : "BEIJING" } }</span>
但是下面这个查询不会用到索引,因为查询的顺序跟索引建立的顺序不一样

<span style="font-family:SimHei;font-size:14px;">> db.factories.find({addr:{state:"BEIJING",city:"BJ"}});</span>


4、组合索引

跟其他数据库产品一样,MongoDB也是有组合索引的,下面我门将在addr.ctiy和addr.state上建立组合索引,当创建组合索引时,字段后面的1表示升序,-1表示降序,是用1还是用-1主要跟排序的时候或者指定范围内查询的时候有关的。

<span style="font-family:SimHei;font-size:14px;">> db.factories.ensureIndex({"addr.city":1,"addr.state":1});
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 2,
        "numIndexesAfter" : 3,
        "ok" : 1
}
> </span>

此时下面查询都用到了这个索引

<span style="font-family:SimHei;font-size:14px;">> db.factories.find({"addr.city":"BJ","addr.state":"BEIJING"});
{ "_id" : ObjectId("54a935b579ceadf5fa8e2ec1"), "name" : "www", "addr" : { "city" : "BJ", "state" : "BEIJING" } }
> </span>
<span style="font-family:SimHei;font-size:14px;">> db.factories.find({"addr.city":"BJ"});
{ "_id" : ObjectId("54a935b579ceadf5fa8e2ec1"), "name" : "www", "addr" : { "city" : "BJ", "state" : "BEIJING" } }
> </span>
<span style="font-family:SimHei;font-size:14px;">> db.factories.find().sort({"addr.city":1,"addr.state":1});
{ "_id" : ObjectId("54a935b579ceadf5fa8e2ec1"), "name" : "www", "addr" : { "city" : "BJ", "state" : "BEIJING" } }
> 
</span>
<span style="font-family:SimHei;font-size:14px;">> db.factories.find().sort({"addr.city":1})
{ "_id" : ObjectId("54a935b579ceadf5fa8e2ec1"), "name" : "www", "addr" : { "city" : "BJ", "state" : "BEIJING" } }
> 
</span>

5、唯一索引

只需要在ensureIndex命令中指定unique:true即可创建唯一索引,比如往表t4中插入两条记录:

<span style="font-family:SimHei;font-size:14px;">> db.t4.insert({firstname:"wang",lastname:"wu"});
WriteResult({ "nInserted" : 1 })
> db.t4.insert({firstname:"wang",lastname:"liu"});
WriteResult({ "nInserted" : 1 })
> 
</span>
在t4表中建立唯一索引

<span style="font-family:SimHei;font-size:14px;">> db.t4.ensureIndex({firstname:1,lastname:1},{unique:true});
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 1,
        "numIndexesAfter" : 2,
        "ok" : 1
}</span>
查看索引:

<span style="font-family:SimHei;font-size:14px;">> db.t4.getIndexes();
[
        {
                "v" : 1,
                "key" : {
                        "_id" : 1
                },
                "name" : "_id_",
                "ns" : "test.t4"
        },
        {
                "v" : 1,
                "unique" : true,
                "key" : {
                        "firstname" : 1,
                        "lastname" : 1
                },
                "name" : "firstname_1_lastname_1",
                "ns" : "test.t4"
        }
]</span>

6、强制使用索引

hint命令可以强制使用某个索引

<span style="font-family:SimHei;font-size:14px;">> db.t5.insert({name:"wangwu",age:20});
WriteResult({ "nInserted" : 1 })
> </span>
创建索引

<span style="font-family:SimHei;font-size:14px;">> db.t5.ensureIndex({name:1,age:1})
{
        "createdCollectionAutomatically" : false,
        "numIndexesBefore" : 1,
        "numIndexesAfter" : 2,
        "ok" : 1
}</span>
查询(没有使用索引)

<span style="font-family:SimHei;font-size:14px;">> db.t5.find({age:{$lt:30}}).explain()
{
        "cursor" : "BasicCursor",
        "isMultiKey" : false,
        "n" : 1,
        "nscannedObjects" : 1,
        "nscanned" : 1,
        "nscannedObjectsAllPlans" : 1,
        "nscannedAllPlans" : 1,
        "scanAndOrder" : false,
        "indexOnly" : false,
        "nYields" : 0,
        "nChunkSkips" : 0,
        "millis" : 0,
        "server" : "localhost.localdomain:27017",
        "filterSet" : false
}</span>
强制使用索引

<span style="font-family:SimHei;font-size:14px;">> db.t5.find({age:{$lt:30}}).hint({name:1,age:1}).explain()
{
        "cursor" : "BtreeCursor name_1_age_1",
        "isMultiKey" : false,
        "n" : 1,
        "nscannedObjects" : 1,
        "nscanned" : 1,
        "nscannedObjectsAllPlans" : 1,
        "nscannedAllPlans" : 1,
        "scanAndOrder" : false,
        "indexOnly" : false,
        "nYields" : 0,
        "nChunkSkips" : 0,
        "millis" : 37,
        "indexBounds" : {
                "name" : [
                        [
                                {
                                        "$minElement" : 1
                                },
                                {
                                        "$maxElement" : 1
                                }
                        ]
                ],
                "age" : [
                        [
                                {
                                        "$minElement" : 1
                                },
                                {
                                        "$maxElement" : 1
                                }
                        ]
                ]
        },
        "server" : "localhost.localdomain:27017",
        "filterSet" : false
}</span>

7、删除索引

删除索引分为删除某张表的所有索引 和删除某张表的某个索引,具体如下:

<span style="font-family:SimHei;font-size:14px;">> db.t5.dropIndexes();
{
        "nIndexesWas" : 2,
        "msg" : "non-_id indexes dropped for collection",
        "ok" : 1
}
> </span>
删除t4表中的firstname索引

<span style="font-family:SimHei;font-size:14px;">> db.t4.dropIndex({firstname:1})
{
        "nIndexesWas" : 2,
        "ok" : 0,
        "errmsg" : "can't find index with key:{ firstname: 1.0 }"
}
> 
</span>

-----------------------------------MongoDB系列文章更新-----------------------

第一部分 基础篇 第一章 走进MongoDB

第一部分 基础篇 第二章 安装MongoDB

第一部分 基础篇 第三章 MongoDB体系结构

第一部分 基础篇 第四章 MongoDB快速入门

第一部分 基础篇 第四章 MongoDB查询

第二部分 应用篇 第五章 MongoDB高级查询

第二部分 应用篇 第六章 MongoDB GridFS

第二部分 应用篇 第七章 MongoDB MapReduce

第三部分 管理篇 第八章 MongoDB服务管理

第三部分 管理篇 第九章 MongoDB shell之系统命令、用户命令

第三部分 管理篇 第九章 MongoDB shell之eval、进程

友情提示:
信息收集于互联网,如果您发现错误或造成侵权,请及时通知本站更正或删除,具体联系方式见页面底部联系我们,谢谢。

其他相似内容:

  • ModernUI课程:定义一个Logo

    ModernUI教程:定义一个Logo ModernWindow的标题栏包含了一块区域用来显示自定义的窗体Logo: 这个窗体logo通过ModernWindow.LogoD...

  • Django忘记管理员账号和密码的解决方法

    Django忘记管理员账号和密码的解决办法 看着Django的教程学习搭建网站,结果忘记第一次创建的账号和密码了。结果搭建成功以后,一直...

  • GO语言小结(1)——基本知识

    GO语言总结(1)——基本知识 1、注释(与C++一样)   行注释://  块注释:/*   ...  */ 2、标识符   可以这么说,除了数字开头...

  • golang 惯用的文件读取方式

    golang 常用的文件读取方式 Golang 的文件读取方法很多,刚上手时不知道怎么选择,所以贴在此处便后速查。 一次性读取 小文件推荐一...

  • 查询深圳市通相关信息

    查询深圳通相关信息 用 HTTP.GET 从开放 API 中查询深圳通信息,然后将 JSON 数据存入结构体中,再格式化输出。 注意:获取的并不是实...

  • Go语言设计模式实践:结合(Composite)

    Go语言设计模式实践:组合(Composite) 关于本系列 这个系列首先是关于Go语言实践的。在项目中实际使用Go语言也有段时间了,一个体会就...

  • 列出索引和遍历目录

    列出目录和遍历目录 获取目录列表用 ioutil.ReadDir(),遍历目录用 filepath.Walk(),使用方法请参考文章示例。 示例代码: package ma...

  • io 包的惯用接口速记

    io 包的常用接口速记 我没有 C/C++ 基础,没有接口的概念,且从 Python 投奔而来,Python 的极简主义(一个结果往往只提供一个方法),让我在...

  • 代理服务扩充

    代理服务扩展 之前自己实现了一个代理服务,当时考虑的是只要支持SOCKS5就好了,因为我经常用CHROME,配合着SwitchySharp,体验还是很棒...

  • 文件的创造与打开

    文件的创建与打开 文件操作是个很重要的话题,使用也非常频繁,熟悉如何操作文件是必不可少的。Golang 对文件的支持是在 os package ...

热门推荐: