加入收藏 | 设为首页 | 会员中心 | 我要投稿 南通站长网 (https://www.0513zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 服务器 > 系统 > 正文

mongodb查询方法

发布时间:2023-12-28 19:55:42 所属栏目:系统 来源:DaWei
导读: 查询操作是MongoDB数据库的常用操作,也是MongoDB学习需要掌握的内容,为帮助大家熟悉MongoDB查询,下面给大家分享一些MongoDB查询实例,感兴趣的朋友可以参考参考。

代码
       查询操作是MongoDB数据库的常用操作,也是MongoDB学习需要掌握的内容,为帮助大家熟悉MongoDB查询,下面给大家分享一些MongoDB查询实例,感兴趣的朋友可以参考参考。

        代码:
db.blogs.insert([
  {
    "author": "张三",
    "title": "MongoDB简介",
    "content": "它是介于关系型数据库和非关系型数据库之间的一种NoSQL数据库,用C++编写,是一款集敏捷性、可伸缩性、
    扩展性于一身的高性能的面向文档的通用数据库",
    "tags": [
      "MongoDB",
      "NoSQL"
    ],
    "comment": [
      {
        "name": "Jack",
        "detail": "Good!",
        "date": ISODate("2015-07-09 09:55:49")
      },
      {
        "name": "Tom",
        "detail": "Hello World!",
        "date": ISODate("2015-07-09 18:12:35")
      },
      {
        "name": "Alice",
        "detail": "你好,Mongo!",
        "date": ISODate("2015-07-10 20:30:30")
      }
    ],
    "readCount": 154
  },
  {
    "author": "李四",
    "title": "1+1等于几",
    "content": "有的人说1+1=2,因为这是老师从小告诉我们的;而有的人说1+1=11,这是两个1的组合;
    但是有些人就认为1+1=1,他们觉得1个团队加上另一个团队,会组成了一个更强大的团队!",
    "tags": [
      "story",
      "rule",
      "数学"
    ],
    "comment": [
      {
        "name": "王小光",
        "detail": "每个人心里边都有自己的答案。",
        "date": ISODate("2015-07-10 11:45:57")
      }
    ],
    "readCount": 367
  },
  {
    "author": "李四",
    "title": "如何写一篇好的博客?",
    "content": "1、目标;2、坚持;3、分享;4、学习;5、提高",
    "tags": null,
    "comment": [
      {
        "name": "小明",
        "detail": "ComeOn!!!!",
        "date": ISODate("2015-07-10 14:49:06")
      },
      {
        "name": "Nike",
        "detail": "终身学习!",
        "date": ISODate("2015-07-11 10:22:36")
      },
      {
        "name": "小红",
        "detail": "贵在坚持吧、",
        "date": ISODate("2015-07-12 12:12:12")
      }
    ],
    "readCount": 1489,
    "isTop": true
  }
])

Test Data
        以上面的测试数据为基础,进行下面的基本查询操作:

        1、查询所有博客

db.blogs.find()

db.blogs.find({})

注:查询一个文档:db.blogs.findOne()
        2、查询所有博客的标题和内容(指定需要返回的键值)

db.blogs.find({},{"title":1,"content":1,"_id":0})
        注:1表示返回,0表示不返回。默认情况下,“_id”这个键总是被返回,即便是没有指定这个键

        3、查询作者为“张三”的博客(=操作)

db.blogs.find({"author":"张三"})

db.blogs.find({"author":{"$eq":"张三"}})
        4、查询除了作者为“张三”的博客(!=操作)

db.blogs.find({"author":{"$ne":"张三"}})
        5、查询作者为“李四”并且博客标题为“MongoDB简介”的博客(and操作)

db.blogs.find({"author":"张三","title":"MongoDB简介"})
        6、查询阅读量大于等于200并且小于1000的博客(>=操作)

db.blogs.find({"readCount":{"$gte":200,"$lt":1000}})
        注:“$lt”,“$lte”,“$gt”,“$gte”分别对应<,<=,>,>=操作

        7、查询作者为“张三”或者“李四”的博客(or操作)

db.blogs.find({"$or":[{"author":"张三"},{"author":"李四"}]})
        8、查询博客标签包含了“NoSQL”或者“数学”的博客(in操作)

db.blogs.find({"tags":{"$in":["NoSQL","数学"]}})
        注:not in操作
db.blogs.find({"tags":{"$nin":["NoSQL","数学"]}}) //不包含
        9、查询标签为空的博客(null操作)

db.blogs.find({"tags":null})
        注:null不仅会匹配到某个键为null的文档,也会匹配不包含这个键的文档

        以上就是关于mongodb查询方法的实例介绍,具有一定的借鉴参考价值,需要的朋友可以看看,希望大家阅读完这篇文章能有所收获。

(编辑:南通站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章