mongodb学习(五) 查询

1. 按条件查询:

db.users.find({"name":"MM1"})

2.find的第二个参数可以指定要返回的字段:这里1 表示要显示的字段,0 表示要剔除的字段

db.users.find({"name":"MM1"},{"name":1,"age":1})
db.users.find({"name":"MM1"},{"name":0})

3. 查询条件: "$lt","$lte","$gt","$gte": <,<=,>,>=

db.users.find({"age":{"$lte":70,"$gte":30}})

4. $in : 匹配指定键的多个值,; $nin和$in相反 $or 匹配多个键的值; $mod取模,将给定值除以第一个数,若余数等于第二个数就返回这条数据

db.users.find({"age":{"$in":[20,25,30]}})
db.users.find({"age":{"$nin":[20,25,30]}})
db.users.find({"$or":[{"age":20},{"winner":"true"}]})
db.users.find({"age":{"$mod":[20,5]}})
db.users.find({"age":{"$not":{"$mod":[20,5]}}})

5. 查询null:

db.users.find({"name":null}) //这样查询出来的还会匹配不包含该键(name)的文档
db.users.fin({"name":{"$in":[null],"$exists":true}}) //使用$exists,就可以准确查出

6. 数组查询:

db.users.find({"fruit":"apple"}) //查询含有apple的数组
db.users.find({"fruit":{"$all":["apple","banana"]}}) //查询包含有apple和banana的数组
db.users.find({"fruit.1":"banana"})//查询数组中第二值为banana的数组,数组是从0开始的

7. 根据数组长度查询:

db.users.find({"fruit":{"$size":3}})
//$size不能和$gte,$lte等合用,可以通过在更新数据时插入一个size字段解决

8. $slice 限制返回的文档数
9. 尽量不使用$where: (1) 查询速度慢-->每个文档都要从BSON转换为js对象,然后通过$where表达式运行; (2)不能使用索引;

10. limit,skip,sort

db.users.find().limit(10).skip(10).sort({"name":1})

避免使用skip略过大量结果. 否则速度会很慢,原因是:首先要找到这些要略过的数据,然后再抛弃这些数据;不使用skip分页的方法:

//(1)获取第一页
var page1=db.users.find().sort({"date"-1}).limit(20)
//(2)使用最后一个date作为查询条件来获取下一页
var lastest=null
whlie(page1.hasNext)){
     lastest=page1.next();
}
var page2=db.users.find({"date":{"$gt":lastest.date}}).sort({"date":-1}).limit(20)

11. 获取随机文档 : 在保存数据时就插入一个随机字段,查询时根据生成的随机数来查找文档

//插入数据
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})
db.users.insert({"name":"11","age":22,"random":Math.random()})

//查询随机文档
var random=Math.random();
db.users.find({"random":{"$gt":random}})
//如果为空可以换为$lt

mongodb学习(五) 查询

时间: 2024-08-02 23:05:49

mongodb学习(五) 查询的相关文章

MongoDB学习笔记(查询)

1.  基本查询:    构造查询数据.    > db.test.findOne()    {         "_id" : ObjectId("4fd58ecbb9ac507e96276f1a"),         "name" : "stephen",         "age" : 35,         "genda" : "male",      

【转】MongoDB学习笔记(查询)

原文地址 MongoDB学习笔记(查询) 基本查询: 构造查询数据. > db.test.findOne() { "_id" : ObjectId("4fd58ecbb9ac507e96276f1a"), "name" : "stephen", "age" : 35, "genda" : "male", "email" : "[em

MongoDB学习笔记(查询)【转】

1.  基本查询:    构造查询数据.    > db.test.findOne()    {         "_id" : ObjectId("4fd58ecbb9ac507e96276f1a"),         "name" : "stephen",         "age" : 35,         "genda" : "male",      

mongoDB 学习五

MongoDB 删除数据库 语法 MongoDB 删除数据库的语法格式如下: db.dropDatabase() 删除当前数据库,默认为 test,你可以使用 db 命令查看当前数据库名. 实例 以下实例我们删除了数据库 runoob. 首先,查看所有数据库: > show dbs local 0.078GB runoob 0.078GB test 0.078GB 接下来我们切换到数据库 runoob: > use runoob switched to db runoob > 执行删除命

MongoDB学习--高级查询 [聚合Group]

Group大约需要一下几个参数. key:用来分组文档的字段.和keyf两者必须有一个 keyf:可以接受一个javascript函数.用来动态的确定分组文档的字段.和key两者必须有一个 initial:reduce中使用变量的初始化 reduce:执行的reduce函数.函数需要返回值. cond:执行过滤的条件. finallize:在reduce执行完成,结果集返回之前对结果集最终执行的函数.可选的 测试数据 //测试的数据 db.stocks.insert({"day": &

MongoDB学习记录

一.操作符 "$lt" :"<""$lte" :"<=""$gt" :">""$gte" :">=""$ne" :"!=""$in" :查询匹配指定条件值的文档:"$nin" :查询不匹配指定条件值的文档:"$or" :或查询

MongoDB的使用学习之(七)MongoDB的聚合查询(两种方式)附项目源码

先来张在路上-- 此项目是用Maven创建的,没有使用Maven的,自己百度.谷歌去:直接用Junit测试就行,先执行里面的save方法,添加10000条测试数据提供各种聚合查询等. 废话不多说,上干货-- 一.MongoDB数据库的配置(mongodb.xml) 以下是我自己的配置,红色字体请改为自己本机的东东,你说不懂设置端口,不会创建数据库名称,不会配置用户名密码,那有请查阅本系列的第4节(MongoDB的使用学习之(四)权限设置--用户名.密码.端口==),你说懒得设置,那就@#¥%--

MongoDB 学习笔记(二) 之查询

最简单的查询 个人认为mongoDB是面向对象的吧. 例如最简单的查询  整个数据集只有三条数据 第一查询姓名为张三的  数据 查询的条件比较好写 随意   db.collection.find(查询条件)   例如 15 得到的结果是这样 如果你不想返回某个字段呢 ,你可以自己定义返回的字段值 语法这样 db.collection.find({查询条件},{返回字段}) 16 我们看到每次查询 "_id" 这个字段 都返回  我们可以将它设置为0 这样的话就不会返回 如 查询条件里的

mongodb 学习笔记 03 -- 查询表达式

mongodb 学习笔记 03 – 查询表达式 不等于,大于,小于 !=: db.stu.find({name:{$ne:'billvsme'}}) 名字不是'billvsme' > : db.stu.find({age:{$gt:18}}) 年纪大于18 < : db.stu.find({age:{$lt:18}}) 年纪小于18 >=: $gte <=: $lte in/not in/all $in :db.goods.find(stu_id:{$in:[93001,93002