• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase
您的位置:首页 > 数据库 >MongoDB > MongoDB教程之索引介绍

MongoDB教程之索引介绍

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-11

通过本文主要向大家介绍了mongodb索引,mongodb 唯一索引,mongodb 空间索引,mongodb 全文索引,mongodb创建索引等相关知识,希望本文的分享对您有所帮助

一、索引基础:

    MongoDB的索引几乎与传统的关系型数据库一模一样,这其中也包括一些基本的优化技巧。下面是创建索引的命令:
      > db.test.ensureIndex({"username":1})
 </div>
    可以通过下面的名称查看索引是否已经成功建立:
      > db.test.getIndexes()
 </div>
    删除索引的命令是:
      > db.test.dropIndex({"username":1})
 </div>
    在MongoDB中,我们同样可以创建复合索引,如:
      -- 数字1表示username键的索引按升序存储,-1表示age键的索引按照降序方式存储。
    > db.test.ensureIndex({"username":1, "age":-1})
 </div>
    该索引被创建后,基于username和age的查询将会用到该索引,或者是基于username的查询也会用到该索引,但是只是基于age的查询将不会用到该复合索引。因此可以说,如果想用到复合索引,必须在查询条件中包含复合索引中的前N个索引列。然而如果查询条件中的键值顺序和复合索引中的创建顺序不一致的话,MongoDB可以智能的帮助我们调整该顺序,以便使复合索引可以为查询所用。如:
      > db.test.find({"age": 30, "username": "stephen"})
 </div>
    对于上面示例中的查询条件,MongoDB在检索之前将会动态的调整查询条件文档的顺序,以使该查询可以用到刚刚创建的复合索引。
    我们可以为内嵌文档创建索引,其规则和普通文档没有任何差别,如:
      > db.test.ensureIndex({"comments.date":1})
 </div>
    对于上面创建的索引,MongoDB都会根据索引的keyname和索引方向为新创建的索引自动分配一个索引名,下面的命令可以在创建索引时为其指定索引名,如:
      > db.test.ensureIndex({"username":1},{"name":"testindex"}) 
 </div>
    随着集合的增长,需要针对查询中大量的排序做索引。如果没有对索引的键调用sort,MongoDB需要将所有数据提取到内存并排序。因此在做无索引排序时,如果数据量过大以致无法在内存中进行排序,此时MongoDB将会报错。
   
二、唯一索引:
    在缺省情况下创建的索引均不是唯一索引。下面的示例将创建唯一索引,如:
      > db.test.ensureIndex({"userid":1},{"unique":true})
 </div>
    如果再次插入userid重复的文档时,MongoDB将报错,以提示插入重复键,如:
      > db.test.insert({"userid":5})
    > db.test.insert({"userid":5})
    E11000 duplicate key error index: test.test.$userid_1  dup key: { : 5.0 }   
 </div>
    如果插入的文档中不包含userid键,那么该文档中该键的值为null,如果多次插入类似的文档,MongoDB将会报出同样的错误,如:
      > db.test.insert({"userid1":5})
    > db.test.insert({"userid1":5})
    E11000 duplicate key error index: test.test.$userid_1  dup key: { : null }  
 </div>
    如果在创建唯一索引时已经存在了重复项,我们可以通过下面的命令帮助我们在创建唯一索引时消除重复文档,仅保留发现的第一个文档,如:
    --先删除刚刚创建的唯一索引。
      > db.test.dropIndex({"userid":1})
    --插入测试数据,以保证集合中有重复键存在。
    > db.test.remove()
    > db.test.insert({"userid":5})
    > db.test.insert({"userid":5})   
    --创建唯一索引,并消除重复数据。
    > db.test.ensureIndex({"userid":1},{"unique":true,"dropDups":true})   
    --查询结果确认,重复的键确实在创建索引时已经被删除。
    > db.test.find()
    { "_id" : ObjectId("4fe823c180144abd15acd52e"), "userid" : 5 }   
    </div>
    我们同样可以创建复合唯一索引,即保证复合键值唯一即可。如:
      > db.test.ensureIndex({"userid":1,"age":1},{"unique":true})   
    </div>

三、使用explain:
    explain是非常有用的工具,会帮助你获得查询方面诸多有用的信息。只要对游标调用该方法,就可以得到查询细节。explain会返回一个文档,而不是游标本身。如:
      > db.test.find().explain()
    {
        "cursor" : "BasicCursor",
        "nscanned" : 1,
        "nscannedObjects" : 1,
        "n" : 1,
  &

分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • mongodb处理中文索引与查找字符串详解
  • MongoDB数据库中索引(index)详解
  • MongoDB的基础查询和索引操作方法总结
  • Mongodb索引的优化
  • MongoDB索引使用详解
  • MongoDB教程之索引介绍
  • MongoDB中创建索引需要注意的事项
  • MongoDB入门教程之索引操作浅析

相关文章

  • 2017-05-11Windows下MongoDB配置用户权限实例
  • 2017-05-11mac下使用brew 安装mongodb的方法教程
  • 2017-05-11Mongodb聚合函数count、distinct、group如何实现数据聚合操作
  • 2017-05-11MongoDB的PHP驱动方法与技巧
  • 2017-05-11mongodb数据库游标的使用浅析
  • 2017-05-11MongoDB安全配置详解
  • 2017-05-11阿里云CentOS7安装Mongodb教程
  • 2017-05-11MongoDB系列教程(四):设置用户访问权限
  • 2017-05-11MongoDB错误32-bit servers don't have journaling enabled by default解决方法
  • 2017-05-11CentOS 6.5 x64系统中安装MongoDB 2.6.0二进制发行版教程

文章分类

  • MsSql
  • Mysql
  • oracle
  • MariaDB
  • DB2
  • SQLite
  • PostgreSQL
  • MongoDB
  • Redis
  • Access
  • 数据库其它
  • sybase
  • HBase

最近更新的内容

    • Mongodb启动命令参数中文说明
    • Mongodb增加、移除Shard Server实例
    • MongoDB的创建、更新和删除
    • MongoDB与MySQL的操作对比表及区别介绍
    • MongoDB的分片集群基本配置教程
    • MongoDB入门教程之分片技术详解
    • MongoDB数据库的特色和优点介绍
    • MongoDB系列教程(八):GridFS存储详解
    • MongoDB教程之数据操作实例
    • 1亿条记录的MongoDB数据库随机查询性能测试

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有