文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

3.mongodb 查询

2024-04-02 19:55

关注

MongoDB 查询文档使用 find() 方法。

find() 方法以非结构化的方式来显示所有文档。

语法格式如下:

db.collection.find(query, projection)

query :可选,使用查询操作符指定查询条件

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


#在find后面加上pretty 方法后还可以更容易阅读的格式来显示:

 db.tmp.find()

{ "_id" : ObjectId("5c1757c7f4e84940e0bd578b"), "name" : "aaa", "pwd" : "123", "birthday" : ISODate("1995-09-05T00:00:00Z") }

{ "_id" : ObjectId("5c1757f5f4e84940e0bd578c"), "name" : "bbb", "pwd" : "321", "birthday" : ISODate("1999-10-10T00:00:00Z") }

{ "_id" : ObjectId("5c177b84f4e84940e0bd578d"), "name" : "suhaozhi", "pwd" : "suhaozhi", "phone" : [ { "phone_num" : "13333333333", "type" : "cmcc" }, { "phone_num" : 15555555555, "type" : "chinanet" } ], "type" : "chinanet" }

{ "_id" : ObjectId("5c177ba1f4e84940e0bd578e"), "name" : "suhaozhi", "pwd" : "su", "phone" : [ { "phone_num" : "13333333332", "type" : "cmcc" }, { "phone_num" : 15655555555, "type" : "cnnet" } ] }

{ "_id" : ObjectId("5c178a62b1d327866c98c9f7"), "x" : "y" }

{ "_id" : ObjectId("5c1f226c87756129d06d2718"), "username" : "aaa", "phone_num" : "13333333333" }

{ "_id" : ObjectId("5c1f232587756129d06d2719"), "username" : "bbb", "phone_num" : [ "123", "456" ] }

mgset-6039947:PRIMARY> db.tmp.find().pretty()

{

"_id" : ObjectId("5c1757c7f4e84940e0bd578b"),

"name" : "aaa",

"pwd" : "123",

"birthday" : ISODate("1995-09-05T00:00:00Z")

}

{

"_id" : ObjectId("5c1757f5f4e84940e0bd578c"),

"name" : "bbb",

"pwd" : "321",

"birthday" : ISODate("1999-10-10T00:00:00Z")

}

{

"_id" : ObjectId("5c177b84f4e84940e0bd578d"),

"name" : "suhaozhi",

"pwd" : "suhaozhi",

"phone" : [

{

"phone_num" : "13333333333",

"type" : "cmcc"

},

{

"phone_num" : 15555555555,

"type" : "chinanet"

}

],

"type" : "chinanet"

}

{

"_id" : ObjectId("5c177ba1f4e84940e0bd578e"),

"name" : "suhaozhi",

"pwd" : "su",

"phone" : [

{

"phone_num" : "13333333332",

"type" : "cmcc"

},

{

"phone_num" : 15655555555,

"type" : "cnnet"

}

]

}

{ "_id" : ObjectId("5c178a62b1d327866c98c9f7"), "x" : "y" }

{

"_id" : ObjectId("5c1f226c87756129d06d2718"),

"username" : "aaa",

"phone_num" : "13333333333"

}

{

"_id" : ObjectId("5c1f232587756129d06d2719"),

"username" : "bbb",

"phone_num" : [

"123",

"456"

]

}


查询条件:

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


操作格式范例RDBMS中的类似语句
等于{<key>:<value>}db.col.find({"by":"菜鸟教程"}).pretty()where by = '菜鸟教程'
小于{<key>:{$lt:<value>}}db.col.find({"likes":{$lt:50}}).pretty()where likes < 50
小于或等于{<key>:{$lte:<value>}}db.col.find({"likes":{$lte:50}}).pretty()where likes <= 50
大于{<key>:{$gt:<value>}}db.col.find({"likes":{$gt:50}}).pretty()where likes > 50
大于或等于{<key>:{$gte:<value>}}db.col.find({"likes":{$gte:50}}).pretty()where likes >= 50
不等于{<key>:{$ne:<value>}}db.col.find({"likes":{$ne:50}}).pretty()where likes != 50


AND 条件查询:

MongoDB 的 find() 方法可以传入多个键(key),每个键(key)以逗号隔开,即常规 SQL 的 AND 条件。

例:

db.col.find({key1:value1, key2:value2}).pretty()


or 条件查询:

MongoDB OR 条件语句使用了关键字 $or,语法格式如下:

>db.col.find(

   {

      $or: [

         {key1: value1}, {key2:value2}

      ]

   }

).pretty()



and与or联合使用:

以下实例演示了 AND 和 OR 联合使用,类似常规 SQL 语句为: 'where age<40 AND (name = 'ayumi' OR jobs = 'singer')


db.col.find({"age": {$lt:40}, $or: [{"name": "ayumi"},{"jobs": singer"}]}).pretty()



对内嵌文档进行操作:

假如说我们这个集合里面的文档都是这种格式:

{ "_id" : ObjectId("5c177b84f4e84940e0bd578d"), "name" : "suhaozhi", "pwd" : "suhaozhi", "phone" : [ { "phone_num" : "13333333333", "type" : "cmcc" }, { "phone_num" : 15555555555, "type" : "chinanet" } ], "type" : "chinanet" }

现在需要搜索出phone字段中type子字段的值为CMCC的记录。

db.tmp.find({phone:{$elemMatch:{cs:"cmcc"}}});



阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯