1.MongoDB 条件操作符

描述

条件操作符用于比较两个表达式并从mongoDB集合中获取数据。

在本章节中,我们将讨论如何在MongoDB中使用条件操作符。

MongoDB中条件操作符有:

    • (>) 大于 - $gt
    • (<) 小于 - $lt
    • (>=) 大于等于 - $gte
    • (<= ) 小于等于 - $lte

MongoDB (>) 大于操作符 - $gt

>
> db.col1.find()
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
{ "_id" : ObjectId("59aaa48ab211b47e25634652"), "name" : "300567", "price" : 59 }
{ "_id" : ObjectId("59aaa4b6b211b47e25634653"), "name" : "300000", "price" : 59 }
> db.col1.find({'price':{$gt:58}})
{ "_id" : ObjectId("59aaa48ab211b47e25634652"), "name" : "300567", "price" : 59 }
{ "_id" : ObjectId("59aaa4b6b211b47e25634653"), "name" : "300000", "price" : 59 }
>

类似于SQL语句:

Select * from col1 where price > 58;

MongoDB (<) 小于操作符 - $lt

> db.col1.find({'price':{$lt:58}})
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
>

类似于SQL语句:

Select * from col1 where price < 58;

MongoDB(>=)大于等于操作符 - $gte

> db.col1.find({'price':{$gte:58}})
{ "_id" : ObjectId("59aaa48ab211b47e25634652"), "name" : "300567", "price" : 59 }
{ "_id" : ObjectId("59aaa4b6b211b47e25634653"), "name" : "300000", "price" : 59 }
>

类似于SQL语句:

Select * from col1 where price >= 58;

MongoDB (<=) 小于操作符 - $lte

> db.col1.find({'price':{$lte:58}})
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
>

类似于SQL语句:

Select * from col1 where price <= 58;

MongoDB 使用 (<) 和 (>) 查询 - $lt 和 $gt

> db.col1.find({'price':{$lt:58,$gt:56}})
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
>
类似于SQL语句:
Select * from col1 where price>56 AND price<58;

MongoDB $type 操作符

在本章节中,我们将继续讨论MongoDB中条件操作符 $type。

$type操作符是基于BSON类型来检索集合中匹配的数据类型,并返回结果。

MongoDB 中可以使用的类型如下表所示:

类型    数字    备注
Double 1
String 2
Object 3
Array 4
Binary data 5
Undefined 6 已废弃。
Object id 7
Boolean 8
Date 9
Null 10
Regular Expression 11
JavaScript 13
Symbol 14
JavaScript (with scope) 15
32-bit integer 16
Timestamp 17
64-bit integer 18
Min key 255 Query with -1.
Max key 127
> db.col1.find()
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
{ "_id" : ObjectId("59aaa48ab211b47e25634652"), "name" : "300567", "price" : 59 }
{ "_id" : ObjectId("59aaa4b6b211b47e25634653"), "name" : "300000", "price" : 59 }
> db.col1.find({'price':{$type:2}})
> db.col1.find({'price':{$type:1}})
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "name" : "300567", "price" : 57 }
{ "_id" : ObjectId("59aaa48ab211b47e25634652"), "name" : "300567", "price" : 59 }
{ "_id" : ObjectId("59aaa4b6b211b47e25634653"), "name" : "300000", "price" : 59 }
>

2.MongoDB Limit与Skip方法


MongoDB Limit() 方法

如果你需要在MongoDB中读取指定数量的数据记录,可以使用MongoDB的Limit方法,limit()方法接受一个数字参数,该参数指定从MongoDB中读取的记录条数。

语法

limit()方法基本语法如下所示:

>db.COLLECTION_NAME.find().limit(NUMBER)
> db.col1.find({'price':{$type:1}},{_id:0}).limit(1)
{ "name" : "300567", "price" : 57 }
> db.col1.find({'price':{$type:1}},{_id:1}).limit(1)
{ "_id" : ObjectId("59aaa2cab211b47e25634651") }
> db.col1.find({'price':{$type:1}},{_id:1,'price':1}).limit(1)
{ "_id" : ObjectId("59aaa2cab211b47e25634651"), "price" : 57 }
> db.col1.find({'price':{$type:1}},{_id:0,'price':1}).limit(1)
{ "price" : 57 }
> db.col1.find({'price':{$type:1}},{_id:0}).limit(1)
{ "name" : "300567", "price" : 57 }
> db.col1.find({'price':{$type:1}},{_id:0}).limit(1)
{ "name" : "300567", "price" : 57 }
>

注:如果你们没有指定limit()方法中的参数则显示集合中的所有数据。


MongoDB Skip() 方法

我们除了可以使用limit()方法来读取指定数量的数据外,还可以使用skip()方法来跳过指定数量的数据,skip方法同样接受一个数字参数作为跳过的记录条数。

语法

skip() 方法脚本语法格式如下:

>db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)
> db.col1.find({'price':{$type:1}},{_id:0})
{ "name" : "300567", "price" : 57 }
{ "name" : "300567", "price" : 59 }
{ "name" : "300000", "price" : 59 }
> db.col1.find({'price':{$type:1}},{_id:0}).skip(1)
{ "name" : "300567", "price" : 59 }
{ "name" : "300000", "price" : 59 }
> db.col1.find({'price':{$type:1}},{_id:0}).skip(2)
{ "name" : "300000", "price" : 59 }

注:skip()方法默认参数为 0 。

MongoDB 排序


MongoDB sort()方法

在MongoDB中使用使用sort()方法对数据进行排序,sort()方法可以通过参数指定排序的字段,并使用 1 和 -1 来指定排序的方式,其中 1 为升序排列,而-1是用于降序排列。

语法

sort()方法基本语法如下所示:

>db.COLLECTION_NAME.find().sort({KEY:1})
> db.col1.find({'price':{$type:1}},{_id:0}).sort({'price':1})
{ "name" : "300567", "price" : 57 }
{ "name" : "300567", "price" : 59 }
{ "name" : "300000", "price" : 59 }
> db.col1.find({'price':{$type:1}},{_id:0}).sort({'price':-1})
{ "name" : "300567", "price" : 59 }
{ "name" : "300000", "price" : 59 }
{ "name" : "300567", "price" : 57 }
>

MongoDB 索引

索引通常能够极大的提高查询的效率,如果没有索引,MongoDB在读取数据时必须扫描集合中的每个文件并选取那些符合查询条件的记录。

这种扫描全集合的查询效率是非常低的,特别在处理大量的数据时,查询可以要花费几十秒甚至几分钟,这对网站的性能是非常致命的。

索引是特殊的数据结构,索引存储在一个易于遍历读取的数据集合中,索引是对数据库表中一列或多列的值进行排序的一种结构


ensureIndex() 方法

MongoDB使用 ensureIndex() 方法来创建索引。

语法

ensureIndex()方法基本语法格式如下所示:

>db.COLLECTION_NAME.ensureIndex({KEY:1})

语法中 Key 值为你要创建的索引字段,1为指定按升序创建索引,如果你想按降序来创建索引指定为-1即可。

> db.col1.ensureIndex({'title':1})
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 1,
"numIndexesAfter" : 2,
"ok" : 1
}
> db.col1.ensureIndex({'title':1,'price':-1})
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 2,
"numIndexesAfter" : 3,
"ok" : 1
}
> db.col1.ensureIndex({'title':1,'price':-1},{background:true})
{
"createdCollectionAutomatically" : false,
"numIndexesBefore" : 3,
"numIndexesAfter" : 3,
"note" : "all indexes already exist",
"ok" : 1
}
ensureIndex() 接收可选参数,可选参数列表如下:
Parameter Type Description
background Boolean 建索引过程会阻塞其它数据库操作,background可指定以后台方式创建索引,即增加 "background" 可选参数。 "background" 默认值为false。
unique Boolean 建立的索引是否唯一。指定为true创建唯一索引。默认值为false.
name string 索引的名称。如果未指定,MongoDB的通过连接索引的字段名和排序顺序生成一个索引名称。
dropDups Boolean 在建立唯一索引时是否删除重复记录,指定 true 创建唯一索引。默认值为 false.
sparse Boolean 对文档中不存在的字段数据不启用索引;这个参数需要特别注意,如果设置为true的话,在索引字段中不会查询出不包含对应字段的文档.。默认值为 false.
expireAfterSeconds integer 指定一个以秒为单位的数值,完成 TTL设定,设定集合的生存时间。
v index version 索引的版本号。默认的索引版本取决于mongod创建索引时运行的版本。
weights document 索引权重值,数值在 1 到 99,999 之间,表示该索引相对于其他索引字段的得分权重。
default_language string 对于文本索引,该参数决定了停用词及词干和词器的规则的列表。 默认为英语
language_override string 对于文本索引,该参数指定了包含在文档中的字段名,语言覆盖默认的language,默认值为 language.

实例

在后台创建索引:

db.values.ensureIndex({open: 1, close: 1}, {background: true})

通过在创建索引时加background:true 的选项,让创建工作在后台执行

MongoDB学习教程(3)-常用命令的更多相关文章

  1. redis学习-集合set常用命令

    redis学习-集合set常用命令   1.sadd:添加一个元素到集合中(集合中的元素无序的并且唯一) 2.smembers:查看集合中所有的元素(上图事例) 3.srem:删除结合中指定的元素 4 ...

  2. redis学习-散列表常用命令(hash)

    redis学习-散列表常用命令(hash)   hset,hmset:给指定散列表插入一个或者多个键值对 hget,hmget:获取指定散列表一个或者多个键值对的值 hgetall:获取所欲哦键值以及 ...

  3. ###Git 基础图解、分支图解、全面教程、常用命令###

    一.Git 基础图解 转自:http://www.cnblogs.com/yaozhongxiao/p/3811130.html Git 图解剖析 git中文件内容并没有真正存储在索引(.git/in ...

  4. MongoDB基础知识与常用命令

    SQL术语/概念 MongoDB术语/概念 解释/说明 database database 数据库 table collection 数据库表/集合 row document 数据记录行/文档 col ...

  5. Mongodb基本数据类型、常用命令之增加、更新、删除

    1.null---表示空值或者该字段不存在,如{"name":null} 2.布尔 --- 和java中的布尔一样,有两种:true,false,如{"sex" ...

  6. Mysql免安装版配置教程和常用命令图

    Mysql免安装版配置教程 图文版 配置环境变量 新建一个my.ini文件,添加下面内容 [mysqld] basedir=C:\\software\Mysql\mysql-5.7.14-winx64 ...

  7. gitbook 入门教程之常用命令详解

    不论是 gitbook-cli 命令行还是 gitbook editor 编辑器都离不开 gitbook 命令的操作使用,所以再次了解下常用命令. 注意 gitbook-cli 是 gitbook 的 ...

  8. Kafka学习之四 Kafka常用命令

    Kafka常用命令 以下是kafka常用命令行总结: 1.查看topic的详细信息 ./kafka-topics.sh -zookeeper 127.0.0.1:2181 -describe -top ...

  9. mongodb增删改查常用命令总结

    前言 去年我还折腾过mongodb,后来用不到也就没碰了,这就导致了我忘的一干二净,不得不感叹,编程这东西只要不用,就会忘没了.现在我想重拾mongodb,来总结一下常用命令,主要就是增删改查. 另外 ...

  10. Linux学习之路--常用命令讲解

    Linux常用命令讲解 1.命令格式:命令 [-选项]  [参数] 超级用户的提示符是# 一般用户的提示符是$ 如:ls -la /usr说明: 大部分命令遵从该格式多个选项时,可以一起写 eg:ls ...

随机推荐

  1. hibernate 教程(3)—NHibernate查询语言HQL

    NHibernate之旅(3):探索查询之NHibernate查询语言(HQL) 本节内容 NHibernate中的查询方法 NHibernate查询语言(HQL) 1.from子句 2.select ...

  2. PHP初入,简易网页整理(布局&特效的使用)

    html><html> <head> <meta charset="UTF-8"> <title></title> ...

  3. 跨浏览器tab页的通信解决方案尝试

    目标 当前页面需要与当前浏览器已打开的的某个tab页通信,完成某些交互.其中,与当前页面待通信的tab页可以是与当前页面同域(相同的协议.域名和端口),也可以是跨域的. 要实现这个特殊的功能,单单使用 ...

  4. 第二次项目冲刺(Beta阶段)--第四天

    一.站立式会议照片 二.项目燃尽图 三.项目进展 队员  ID 贡献比 王若凡 201421123022 20% 吕志哲 201421123021 16% 欧阳勇 201421123026 16% 卢 ...

  5. 201521123053《Java程序设计》第四周总结

    1. 本周学习总结 1.1 尝试使用思维导图总结有关继承的知识点. 1.2 使用常规方法总结其他上课内容. 现在上课跟着老师的思路走,一般都能理解了.就是课上知识点有些难以记住. 特别讲讲这个思维导图 ...

  6. 201521123052《Java程序设计》第2周学习总结

    1. 本周学习总结 String类一些用法 学习Array类 使用枚举 使用eclipse关联JDK源代码 使用码云管理云代码 2.书面作业 1.使用Eclipse关联jdk源代码,并查看String ...

  7. 201521123115《Java程序设计》第14周学习总结

    1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 2. 书面作业 1. MySQL数据库基本操作 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自 ...

  8. Maven常见错误以及解决方案【转载】

    常见的Maven错误 当遇到401错误的时候,看看自己当前使用的Maven是集成的还是自己下载的,然后去配置setting.xml文件

  9. jquery-easyUI第一篇【介绍、入门、使用常用的组件】

    什么是easyUI 我们可以看官方对easyUI的介绍: easyUI就是一个在Jquery的基础上封装了一些组件-.我们在编写页面的时候,就可以直接使用这些组件-非常方便-easyUI多用于在后台的 ...

  10. Python学习笔记011_模块_标准库_第三方库的安装

    容器 -> 数据的封装 函数 -> 语句的封装 类 -> 方法和属性的封装 模块 -> 模块就是程序 , 保存每个.py文件 # 创建了一个hello.py的文件,它的内容如下 ...