主頁 > 知識庫 > MongoDB的查詢方法

MongoDB的查詢方法

熱門標(biāo)簽:怎么投訴地圖標(biāo)注 電銷機器人是什么軟件 蘋果汽車租賃店地圖標(biāo)注 呼和浩特電銷外呼系統(tǒng)加盟 云南外呼系統(tǒng) 杭州人工電銷機器人價格 老虎洗衣店地圖標(biāo)注 廣州長安公司怎樣申請400電話 濟南電銷機器人加盟公司

代碼:

db.blogs.insert([
  {
    "author": "張三",
    "title": "MongoDB簡介",
    "content": "它是介于關(guān)系型數(shù)據(jù)庫和非關(guān)系型數(shù)據(jù)庫之間的一種NoSQL數(shù)據(jù)庫,用C++編寫,是一款集敏捷性、可伸縮性、擴展性于一身的高性能的面向文檔的通用數(shù)據(jù)庫",
    "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",
      "數(shù)學(xué)"
    ],
    "comment": [
      {
        "name": "王小光",
        "detail": "每個人心里邊都有自己的答案。",
        "date": ISODate("2015-07-10 11:45:57")
      }
    ],
    "readCount": 367
  },
  {
    "author": "李四",
    "title": "如何寫一篇好的博客?",
    "content": "1、目標(biāo);2、堅持;3、分享;4、學(xué)習(xí);5、提高",
    "tags": null,
    "comment": [
      {
        "name": "小明",
        "detail": "ComeOn!!!!",
        "date": ISODate("2015-07-10 14:49:06")
      },
      {
        "name": "Nike",
        "detail": "終身學(xué)習(xí)!",
        "date": ISODate("2015-07-11 10:22:36")
      },
      {
        "name": "小紅",
        "detail": "貴在堅持吧、",
        "date": ISODate("2015-07-12 12:12:12")
      }
    ],
    "readCount": 1489,
    "isTop": true
  }
])

Test Data

以上面的測試數(shù)據(jù)為基礎(chǔ),進行下面的基本查詢操作:

1、查詢所有博客

db.blogs.find()
或
db.blogs.find({})

注:查詢一個文檔:db.blogs.findOne()

2、查詢所有博客的標(biāo)題和內(nèi)容(指定需要返回的鍵值)

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、查詢作者為“李四”并且博客標(biāo)題為“MongoDB簡介”的博客(and操作)

db.blogs.find({"author":"張三","title":"MongoDB簡介"})

6、查詢閱讀量大于等于200并且小于1000的博客(>=操作)

db.blogs.find({"readCount":{"$gte":200,"$lt":1000}})

注:“$lt”,“$lte”,“$gt”,“$gte”分別對應(yīng),=,>,>=操作

7、查詢作者為“張三”或者“李四”的博客(or操作)

db.blogs.find({"$or":[{"author":"張三"},{"author":"李四"}]})

8、查詢博客標(biāo)簽包含了“NoSQL”或者“數(shù)學(xué)”的博客(in操作)

db.blogs.find({"tags":{"$in":["NoSQL","數(shù)學(xué)"]}})

注:not in操作

db.blogs.find({"tags":{"$nin":["NoSQL","數(shù)學(xué)"]}}) //不包含

9、查詢標(biāo)簽為空的博客(null操作)

db.blogs.find({"tags":null})

注:null不僅會匹配到某個鍵為null的文檔,也會匹配不包含這個鍵的文檔

10、查詢內(nèi)容里邊包含了數(shù)字“1”的博客

db.blogs.find({"content":/1/})

注:只要符合常規(guī)正則表達式的,都能被MongoDB接受
數(shù)組操作

11、查詢標(biāo)簽里邊既包含“story”,又包含了“rule”的博客

db.blogs.find({"tags":{"$all":["story","rule"]}})

12、查詢第一個標(biāo)簽是“MongoDB”的博客

db.blogs.find({"tags.0":"MongoDB"})

注:數(shù)組的下標(biāo)是從0開始的

13、查詢標(biāo)簽個數(shù)為3個的博客

db.blogs.find({"tags":{"$size":3}})

內(nèi)嵌文檔

14、查詢“jack”評論過的博客

db.blogs.find({"comment.name":"Jack"})

注:因為內(nèi)嵌文檔“.”的問題,所以不能使用URL等

15、假設(shè)每頁2篇博客,按閱讀量倒序,取第二頁的數(shù)據(jù)

db.blogs.find({}).skip(2).limit(2).sort({"readCount":-1})

注:skip()、limit()、sort(),分別表示略過文檔的數(shù)量,匹配的數(shù)量和排序(1表示正序,-1表示倒序)

標(biāo)簽:無錫 雞西 玉林 自貢 興安盟 廈門 泰安 遼陽

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《MongoDB的查詢方法》,本文關(guān)鍵詞  MongoDB,的,查詢,方法,MongoDB,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《MongoDB的查詢方法》相關(guān)的同類信息!
  • 本頁收集關(guān)于MongoDB的查詢方法的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章