MongoDB笔记(五) —— 查询文档

语法:

db.collection.find(query, projection)
  • 参数说明
    • query :可选,使用查询操作符指定查询条件
    • projection :可选,使用投影操作符指定返回的键。查询时返回文档中所有键值, 只需省略该参数即可(默认省略)。

格式化:

> db.demo.find().pretty()

操作符查询:

  • 大于:(greater than >) $gt
  • 大于等于:(gt equal >=) $gte
  • 小于:(less than <) $lt
  • 小于等于:(lt equal <=) $lte
  • 匹配:(equal =) $eq
  • 不匹配:( not equal !=) $ne
  • 包含:(like) /val1/
  • 开头:(like) /^val1/
  • 结尾:(like) /val1$/

MongoDB 与 RDBMS Where 语句比较

如果你熟悉常规的 SQL 数据,通过下表可以更好的理解 MongoDB 的条件语句查询:

操作格式范例RDBMS中的类似语句
大于{<key>:{$gt:<val>}}db.demo.find({"age":{$gt:20}}).pretty()where age > 20
大于或等于{<key>:{$gte:<val>}}db.demo.find({"age":{$gte:20}}).pretty()where age >= 20
小于{<key>:{$lt:<val>}}db.demo.find({"age":{$lt:20}}).pretty()where age < 20
小于或等于{<key>:{$lte:<val>}}db.demo.find({"age":{$lte:20}}).pretty()where age <= 20
等于{<key>:<val>}db.demo.find({"name":"yourName"}).pretty()where name = 'yourName'
不等于{<key>:{$ne:<val>}}db.demo.find({"age":{$ne:20}}).pretty()where age != 20

and查询:

> db.demo.find({key1:val1, key2:val2}).pretty()

or查询:

> db.demo.find({$or: [{key1: val1}, {key2:val2}]}).pretty()

and,or查询:

> db.demo.find({"key1": "val1", $or: [{"key2": "val2"},{"key3": "val3"}]}).pretty()

$type查询

类型数字备注
Double1
String2
Object3
Array4
Binary data5
Undefined6已废弃。
Object id7
Boolean8
Date9
Null10
Regular Expression11
JavaScript13
Symbol14
JavaScript (with scope)15
32-bit integer16
Timestamp17
64-bit integer18
Min key255Query with -1.
Max key127

查询name为String的数据

db.demo.find({"name" : {$type : 2}})
或
db.demo.find({"name" : {$type : 'string'}})
> db.demo.find()
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "yourName", "age" : 20, "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find({"name":{$type:2}})
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "yourName", "age" : 20, "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find({"name":{$type:'string'}})
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "yourName", "age" : 20, "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find({"name":{$type:3}})
> 

limit(限定查询数量)

> db.COLLECTION_NAME.find().limit(NUMBER)

skip(跳过数据数量)

> db.COLLECTION_NAME.find().limit(NUMBER).skip(NUMBER)

sort(排序)

> db.COLLECTION_NAME.find().sort({KEY:1})
> db.demo.find()
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "hisName", "age" : 20, "hobby" : [ "drawing", "run" ] }
{ "_id" : ObjectId("5e79a878a3edd4aa4ff0c2c4"), "name" : "yourName", "age" : "30", "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find().sort({"age":1})
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "hisName", "age" : 20, "hobby" : [ "drawing", "run" ] }
{ "_id" : ObjectId("5e79a878a3edd4aa4ff0c2c4"), "name" : "yourName", "age" : "30", "hobby" : [ "drawing", "run" ] }
>
>  db.demo.find().sort({"age":-1})
{ "_id" : ObjectId("5e79a878a3edd4aa4ff0c2c4"), "name" : "yourName", "age" : "30", "hobby" : [ "drawing", "run" ] }
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "hisName", "age" : 20, "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find().sort({"name":-1})
{ "_id" : ObjectId("5e79a878a3edd4aa4ff0c2c4"), "name" : "yourName", "age" : "30", "hobby" : [ "drawing", "run" ] }
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "hisName", "age" : 20, "hobby" : [ "drawing", "run" ] }
> 
> db.demo.find().sort({"name":1})
{ "_id" : ObjectId("5e79a57ba3edd4aa4ff0c2c3"), "name" : "hisName", "age" : 20, "hobby" : [ "drawing", "run" ] }
{ "_id" : ObjectId("5e79a878a3edd4aa4ff0c2c4"), "name" : "yourName", "age" : "30", "hobby" : [ "drawing", "run" ] }
> 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值