MongoDB 查询操作的实例详解
MongoDB 查询操作的实例详解
使用find或findOne进行查询。并可以进行范围查询、数据集查询、不等式查询,以及其他的一些查询。
查询将会返回DBcursor 游标只有在你需要的时候返回文档
针对游标返回的文档(结果集) 进行操作 例如:忽略一定数量的结果,或者返回结果的数量,以及对结果的排序。
1.指定需要返回的键
有时候仅仅对文档的某几个键值感兴趣,可以屏蔽返回的不感兴趣的键值,返回感兴趣的键值
mongos> db.blog.find({},{“name”:1}) { “_id” : ObjectId(“5659836e73c8340448fa470e”) } { “_id” : ObjectId(“565e5c0e73c8340448fa470f”) } { “_id” : ObjectId(“565f998e73c8340448fa4710”) } { “_id” : 1, “name” : “zmkzmkzmkzmkzmk” } { “_id” : 2, “name” : “zmkzmkzmkzmkzmk” } { “_id” : 3, “name” : “zmkzmkzmkzmkzmk” } { “_id” : ObjectId(“566004d173c8340448fa4712”), “name” : “zmk” }
可以这样:
mongos> db.blog.find({},{“name”:1,”_id”:0}) { “name” : “zmkzmkzmkzmkzmk” } { “name” : “zmkzmkzmkzmkzmk” } { “name” : “zmkzmkzmkzmkzmk” } { “name” : “zmk” }
指定返回的键值,是查询结果更高效。此接口可用于条件查询,方便结果处理。
2.查询条件
比较操作符
"$lt"、"$lte"、“$gt”,“$gte” 分别对应 <,<=,>,>=。
小贴士:在mongodb shell中定义方法的大概格式:
mongos> var insertName=function(){ … for(var i=0;i<10;i++){ … db.blog.insert({“_id”:1,”name”:”zmk”+i}) … } … } mongos> insertName()
效果:
mongos> db.blog.find() { “_id” : 1, “name” : “zmk0” } { “_id” : 0, “name” : “zmk0” } { “_id” : 2, “name” : “zmk2” } { “_id” : 3, “name” : “zmk3” } { “_id” : 4, “name” : “zmk4” } { “_id” : 5, “name” : “zmk5” } { “_id” : 6, “name” : “zmk6” } { “_id” : 7, “name” : “zmk7” } { “_id” : 8, “name” : “zmk8” } { “_id” : 9, “name” : “zmk9” }
观察下面的效果,find可以使用“$lt”<来查询文件插入的时间
mongos> db.blog.insert({“_id”:10,”time”:new Date()}) WriteResult({ “nInserted” : 1 }) mongos> db.blog.find({“time”:{“$lt”:new Date()}}) { “_id” : 10, “time” : ISODate(“2015-12-05T12:08:53.469Z”) }
3.查询数组
1.$all
应用于多个元素匹配数组,且并无顺序。
mongos> db.blog.insert({“_id”:1,”fruit”:[“apple”,”banana”,”peach”]}) WriteResult({ “nInserted” : 1 }) mongos> db.blog.insert({“_id”:2,”fruit”:[“apple”,”kumquat”,”orange”]}) WriteResult({ “nInserted” : 1 }) mongos> db.blog.insert({“_id”:3,”fruit”:[“cherry”,”banana”,”apple”]}) WriteResult({ “nInserted” : 1 }) mongos> db.blog.find({“fruit”:{$all:[“apple”,”banana”]}}) { “_id” : 1, “fruit” : [ “apple”, “banana”, “peach” ] } { “_id” : 3, “fruit” : [ “cherry”, “banana”, “apple” ] }
对数组进行精确匹配,可以使用key.index语法指定下标
mongos> db.blog.find({“fruit.2”:”peach”}) { “_id” : 1, “fruit” : [ “apple”, “banana”, “peach” ] }
2.$size
查询特定长度的数组。
mongos> db.blog.find({“fruit”:{$size:3}}) { “_id” : 1, “fruit” : [ “apple”, “banana”, “peach” ] } { “_id” : 2, “fruit” : [ “apple”, “kumquat”, “orange” ] } { “_id” : 3, “fruit” : [ “cherry”, “banana”, “apple” ] }
可以再存有数组的文档中添加size键,每一次向指定数组中添加元素,同时增加“size”的值,自增操作非常快,对性能不影响。
3.slice
可以返回某个键匹配的数组元素的一个子集
mongos> db.blog.find({“fruit”:{size:3}},{"fruit":{"slice”:-2}}) { “_id” : 2, “fruit” : [ “kumquat”, “orange” ] } { “_id” : 3, “fruit” : [ “banana”, “apple” ] }
4.查询内嵌文档
点语法即可
mongos>db.people.find({“name.first”:”Joe”,”name.last”:”Schmoe”})
要正确的指定一组元素,而不必指定每个键,则需要使用$elemMatch 用来在查询条件中不非指定匹配数组中的单个内嵌文档。
db.blog.find({“comments”:{“$elemMatch”: {“author”:”joe”,”score”:{“$gte”:5}}}})
5.limit、skip和sort
三个方法可以组合进行分页.
比如你有一个在线商店,有人搜索mp3,若想每页返回50个结果,而且按照价格从高到低升序排列。
db.stock.find({“des”:”mp3”}).limit(50).sort({“price”:-1}) db.stock.find({“des”:”mp3”}).skip(50).limit(50).sort({“price”:-1}) ……
然而略过太多会导致性能问题。
解决方法:尽量避免使用skip略过大量结果。
var page1=db.stock.find({“des”:”mp3”}).limit(50).sort({“price”:-1}) var lastest=null;//解决方法,将游标最后一个文档记录下来,成为第二次查询的条件的一部分 while(page1.hasNext()){ lastest=page1.next(); display(lastest); } var page2=db.stock.find({“des”:”mp3”},{“price”:{$gt:lastest.price}}).limit(50).sort({“price”:-1}) ……
随机选取文档
正确方法是在插入文档时插入一个随机值的键,然后按照普通查询进行find()即可。
感谢阅读,如有疑问请留言或者到本站社区交流讨论,谢谢大家对本站的支持!
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- JFreeChart折线图的生成方法
- JavaScript使用math.js进行精确计算操作示例
- linux环境下编写shell脚本实现启动停止tomcat服务的方法
- JS正则表达式常见用法实例详解
- angular 实现的输入框数字千分位及保留几位小数点功能示例
- JFreeChart简单实现光滑曲线绘制
- 在Golang中使用Redis的方法示例
- python3使用SMTP发送简单文本邮件
- vue异步加载高德地图的实现
- python3.X 抓取火车票信息【修正版】
- shell在指定目录下批量执行sql脚本的实例
- Linux下去掉^M的四种方法
- hive-shell批量命令执行脚本的实现方法
- python3使用SMTP发送HTML格式邮件
- shell传参并将参数传递给sql文件的方法