a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > MongoDB > 正文

MongoDB的查詢方法

2020-03-14 12:57:58
字體:
來源:轉載
供稿:網友

代碼:

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的文檔,也會匹配不包含這個鍵的文檔

10、查詢內容里邊包含了數字“1”的博客

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

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

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

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

12、查詢第一個標簽是“MongoDB”的博客

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

注:數組的下標是從0開始的

13、查詢標簽個數為3個的博客

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

內嵌文檔

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

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

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

15、假設每頁2篇博客,按閱讀量倒序,取第二頁的數據

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

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

 

注:相關教程知識閱讀請移步到MongoDB頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 亚洲国产午夜 | 国偷自产视频一区二区久 | 黄a免费看 | 久久亚洲精品国产亚洲老地址 | 国产精品久久久久久久久久东京 | 精品久久久久久久久久 | a视频在线观看 | 精品视频一区二区 | 青青草一区二区 | 国产精品无码久久久久 | 中文二区 | 国产成人精品一区二区三区视频 | 亚洲成人一区二区 | 久久精品国产一区二区电影 | 日韩在线观看不卡 | 久久久久久国产精品mv | 国产福利资源 | 青青草激情视频 | 99色在线视频 | 超碰激情 | 三级成人在线 | 国产一区二区三区在线免费观看 | 成人免费视频网站在线看 | 久草福利在线视频 | 手机在线观看av | 亚洲日本aⅴ片在线观看香蕉 | 久久公开视频 | 成人在线日韩 | 蕉伊人 | 超碰天堂| 成人a在线| 成人日韩 | 欧美视频免费 | 91精品国产综合久久精品 | 国产精品日韩欧美一区二区三区 | 日日夜夜精品网站 | 中文字幕国产 | 成人免费在线看片 | 美女诱惑av| 欧洲毛片| 免费成人在线网站 |