学习索引分类和创建索引:                
1._id索引 大多数集合默认的索引
2.单键索引:手动创建,一个单一的值
3.多建索引:组合函数
4.复合索引 :最左前缀原则
5.过期索引 :一定时间内失效,注意点:必须是isodate或者其数组,不要使用时间戳,否则不会被自动删除。
6.全文索引 db.tm.ensureindex({"article":"text"}),db.tm.ensureindex({"key1":"text","key2":"text"}),db.tm.ensureindex({$**:"text"})
查询:db.tm.find({$text:{$search:“aa”}})
db.tm.find({$text:{$search:"aa bb cc "}})
db.tm.find({$text:{$search:"aa bb -cc"}})
db.tm.find({$text:{$search:"\"a\"\"bb"\"cc\""}})
全文索引的匹配度$meta
db.tm.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}})
db.tm.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}}).sort({score:{$meta:"textScore"}})
每次只能指定$text
7.地理位置索引(滴滴打车,大众点评)

2d索引(地址位置索引)
db.localtion.ensureindex({"w":"2d"})

查看索引:db.tm.getIndexes()
建索引db.t1.ensureIndex({x:1})
多键索引db.tm.ensureIndex({x:[1,2,3,4,5]})
复合索引 db.tm.ensureIndex({x:1,y:1})
删除索引db.tm.dropIndex("x_1_y_1")
db.tm.find({x:100,y:100}).explain()
过期索引:db.tm.insert({time:new Date()}) ISOdate 就是当前时间
db.tm.ensureIndex({time:1},{expireAfterSeconds:10})
db.tm.insert({time:new Date(),z:1})
全文索引
db.t1.ensureIndex({article:"text"})
db.t1.insert({article:"aa bb cc"})
查找db.t1.find({$text:{$search:"aa"}})
db.t1.find({$text:{$search:"aa bb cc"}})或关系
db.t1.find({$text:{$search:"aa bb -cc"}})不包含CC
db.t1.find({$text:{$search:"\"aa\"\" bb\"\" -cc\""}})且的关系

全文索引的相似度:db.t1.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}})
db.t1.find({$text:{$search:"aa bb"}},{score:{$meta:"textScore"}}).sort({score:{$meta:"textScore"}})

索引命名
db.t1.ensureIndex({x:1,y:2,z:2},{name:"xyz"})
db.t1.dropIndex("xyz")
创建唯一索引
db.t2.ensureIndex({m:1,n:1},{unique:true})

查看s索引存在某个字段

db.abc.find({m:{$exists:true}})

创建2d索引:平面地理位置索引,位置表示方式,经纬度[经度(-180,180),纬度(-90,90)]
db.location.ensureIndex({"w":"2d"})
db.location.insert({w:[1,1]})
db.location.insert({w:[1,2]})
db.location.insert({w:[3,2]})
db.location.insert({w:[32,22]})
db.location.insert({w:[100,90]})
就近查询
db.location.find({w:{$near:[1,1]}})

查询
db.location.find({w:{$near:[1,1],$maxDistance:10}})

地址位置索引
geoNear
db.runCommand({geoNear:"location",near:[1,2],maxDistance:10,num:1})
db.stats

for(i=1;i<10000;i++)db.tt.insert({n:i})

查看运行状态
/export/mongodb/bin/mongostat -h 192.168.1.70:22222
faults locked idx miss没有使用索引值
qr|qw读写队列

查看当前级别
db.getProfilingStatus()
0:profile为关闭,mongodb不会记录任何操作
1配合slowms使用,mongodb会记录任何超过slowms的操作
2会记录任何记录
修改级别profile
db.setProfilingLevel(0)
db.system.profile.find().sort({$natural:1}).limit(10)
查询排序

db.system.indexes.find().sort({$nature:1})

本文转自 DBAspace 51CTO博客,原文链接:http://blog.51cto.com/dbaspace/1869918

mongodb之索引学习相关推荐

  1. 转载:mongoDB java驱动学习笔记

    http://www.blogjava.net/watchzerg/archive/2012/09/22/388346.html mongoDB java驱动学习笔记 指定新mongo实例: Mong ...

  2. mongoDB配制及学习

    mongoDB配制及学习 http://blog.csdn.net/zj7758/article/details/7102996 ----------------------------------- ...

  3. MongoDB快速上手、windows安装、常用命令、文档基本增删改查、mongoDB的索引

    MongoDB快速上手 目标 理解MongoDB的业务场景.熟悉MongoDB的简介.特点和体系结构.数据类型等. 能够在Windows和Linux下安装和启动MongoDB.图形化管理界面Compa ...

  4. Mongodb的索引操作

    Mongodb的索引操作 1. 为什么mongdb需要创建索引 加快查询速度 进行数据的去重 2. mongodb创建简单的索引方法 语法:db.集合名.ensureIndex({属性:1}),1表示 ...

  5. MongoDB复合索引详解

    摘要: 对于MongoDB的多键查询,创建复合索引可以有效提高性能. 什么是复合索引? 复合索引,即Compound Index,指的是将多个键组合到一起创建索引,这样可以加速匹配多个键的查询.不妨通 ...

  6. MySQL中的联合索引学习教程

    MySQL中的联合索引学习教程 这篇文章主要介绍了MySQL中的联合索引学习教程,其中谈到了联合索引对排序的优化等知识点,需要的朋友可以参考下 联合索引又叫复合索引.对于复合索引:Mysql从左到右的 ...

  7. MongoDB数据库索引基础知识与实战技巧

    本文内容源自Kyle Banker 的MongoDB In Action一书.主要描述了MongoDB索引相关的一些基础知识和使用技巧. 索引类型 虽然MongoDB的索引在存储结构上都是一样的,但是 ...

  8. Mongodb的索引

    1. 简单介绍 索引是为了加速查询. 假设没有索引,mongodb在查询时会做表扫描,假设集合非常大时,这个查询会非常慢. 一般对创建查询时的键都建立索引. 为排序字段建立索引,假设对未建立索引的字段 ...

  9. 五、MongoDB的索引

    一.MongoDB的下载.安装与部署 二.MongoDB的基础知识简介 三.MongoDB的创建.更新和删除 四.MongoDB的查询 五.MongoDB的索引 1.简介 它就像是一本书的目录,如果没 ...

最新文章

  1. android8.1获取蓝牙地址,[蓝牙] Android 8.1 获取蓝牙设备地址无效;02:00:00:00:00:00
  2. 【Android Demo】悬浮窗体实现
  3. gradle的多项目构建(九)
  4. vb php mysql_VB连接MYSQL数据的方法
  5. 使用.NET Core优雅获取并展示最新疫情数据
  6. [有限元]利用虚位移和虚力的定义、对称性推导弹性力学公式
  7. kubernetes创建yaml,pod服务一直处于 ContainerCreating状态的原因查找与解决
  8. 搜狐“狐友”正式版上线 扩张我的社交圈
  9. 计算机系统中处理的图片可分为,第五章图像处理.doc
  10. RedHat 7配置keepalived+LVS实现高可用的Web负载均衡
  11. android excel布局,Androidui布局控件(2)表格布局excelPanel
  12. SO_REUSEADDR 套接字选项应用实例
  13. 用 Python 写一个安卓 APP
  14. python第三方模块下载方法(最详最细)
  15. Prometheus+Grafana监控系统部署与使用
  16. 用计算机三角函数公式,三角函数公式习题.doc
  17. 城市记忆:(一)灵洲----河奇;(二)富平三迁
  18. 微信小程序开发——调用免费天气api接口(高德、天气API)
  19. Nvidia显卡开启游戏帧数显示
  20. 蓝桥 算法训练 藏匿的刺客(C语言)

热门文章

  1. 小白视角看ros_openvino_toolkit
  2. 关于优酷开发sdkdemo的布局
  3. zynqNet整体思路框架
  4. linux剪贴板复制文件原理,linux剪贴板原理
  5. web.xml里filter-mapping中的dispatcher作用
  6. 启用 HTTP TRACE 方法
  7. 四、MyBatis-映射文件
  8. a标签缺少href 属性,鼠标经过不会出现手型
  9. 验证整数 Double 转 int 两种写法
  10. 获取某年某月的第一天和最后一天的Sql Server函数