四、MongoDB的查詢

來源:互聯網
上載者:User

標籤:

一、MongoDB的下載、安裝與部署

二、MongoDB的基礎知識簡介

三、MongoDB的建立、更新和刪除

 1 db.blogs.insert([ 2     { 3         "author": "張三", 4         "title": "MongoDB簡介", 5         "content": "它是介於關係型資料庫和非關係型資料庫之間的一種NoSQL資料庫,用C++編寫,是一款集敏捷性、延展性、擴充性於一身的高效能的面向文檔的通用資料庫", 6         "tags": [ 7             "MongoDB", 8             "NoSQL" 9         ],10         "comment": [11             {12                 "name": "Jack",13                 "detail": "Good!",14                 "date": ISODate("2015-07-09 09:55:49")15             },16             {17                 "name": "Tom",18                 "detail": "Hello World!",19                 "date": ISODate("2015-07-09 18:12:35")20             },21             {22                 "name": "Alice",23                 "detail": "你好,Mongo!",24                 "date": ISODate("2015-07-10 20:30:30")25             }26         ],27         "readCount": 15428     },29     {30         "author": "李四",31         "title": "1+1等於幾",32         "content": "有的人說1+1=2,因為這是老師從小告訴我們的;而有的人說1+1=11,這是兩個1的組合;但是有些人就認為1+1=1,他們覺得1個團隊加上另一個團隊,會組成了一個更強大的團隊!",33         "tags": [34             "story",35             "rule",36             "數學"37         ],38         "comment": [39             {40                 "name": "王小光",41                 "detail": "每個人心裡邊都有自己的答案。",42                 "date": ISODate("2015-07-10 11:45:57")43             }44         ],45         "readCount": 36746     },47     {48         "author": "李四",49         "title": "如何寫一篇好的部落格?",50         "content": "1、目標;2、堅持;3、分享;4、學習;5、提高",51         "tags": null,52         "comment": [53             {54                 "name": "小明",55                 "detail": "ComeOn!!!!",56                 "date": ISODate("2015-07-10 14:49:06")57             },58             {59                 "name": "Nike",60                 "detail": "終身學習!",61                 "date": ISODate("2015-07-11 10:22:36")62             },63             {64                 "name": "小紅",65                 "detail": "貴在堅持吧、",66                 "date": ISODate("2015-07-12 12:12:12")67             }68         ],69         "readCount": 1489,70         "isTop": true71     }72 ])
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/})

註:只要符合常規Regex的,都能被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的查詢

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.