MongoDB的查詢方法
代碼:
db.blogs.insert([ { "author": "張三", "title": "MongoDB簡(jiǎn)介", "content": "它是介于關(guān)系型數(shù)據(jù)庫(kù)和非關(guān)系型數(shù)據(jù)庫(kù)之間的一種NoSQL數(shù)據(jù)庫(kù),用C++編寫,是一款集敏捷性、可伸縮性、擴(kuò)展性于一身的高性能的面向文檔的通用數(shù)據(jù)庫(kù)", "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": "有的人說(shuō)1+1=2,因?yàn)檫@是老師從小告訴我們的;而有的人說(shuō)1+1=11,這是兩個(gè)1的組合;但是有些人就認(rèn)為1+1=1,他們覺(jué)得1個(gè)團(tuán)隊(duì)加上另一個(gè)團(tuán)隊(duì),會(huì)組成了一個(gè)更強(qiáng)大的團(tuán)隊(duì)!", "tags": [ "story", "rule", "數(shù)學(xué)" ], "comment": [ { "name": "王小光", "detail": "每個(gè)人心里邊都有自己的答案。", "date": ISODate("2015-07-10 11:45:57") } ], "readCount": 367 }, { "author": "李四", "title": "如何寫一篇好的博客?", "content": "1、目標(biāo);2、堅(jiān)持;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": "貴在堅(jiān)持吧、", "date": ISODate("2015-07-12 12:12:12") } ], "readCount": 1489, "isTop": true } ]) Test Data
以上面的測(cè)試數(shù)據(jù)為基礎(chǔ),進(jìn)行下面的基本查詢操作:
1、查詢所有博客
db.blogs.find() 或 db.blogs.find({}) 注:查詢一個(gè)文檔:db.blogs.findOne()
2、查詢所有博客的標(biāo)題和內(nèi)容(指定需要返回的鍵值)
db.blogs.find({},{"title":1,"content":1,"_id":0})
注:1表示返回,0表示不返回。默認(rèn)情況下,“_id”這個(gè)鍵總是被返回,即便是沒(méi)有指定這個(gè)鍵
3、查詢作者為“張三”的博客(=操作)
db.blogs.find({"author":"張三"}) 或 db.blogs.find({"author":{"$eq":"張三"}})
4、查詢除了作者為“張三”的博客(!=操作)
db.blogs.find({"author":{"$ne":"張三"}})
5、查詢作者為“李四”并且博客標(biāo)題為“MongoDB簡(jiǎn)介”的博客(and操作)
db.blogs.find({"author":"張三","title":"MongoDB簡(jiǎn)介"})
6、查詢閱讀量大于等于200并且小于1000的博客(>=操作)
db.blogs.find({"readCount":{"$gte":200,"$lt":1000}})
注:“$lt”,“$lte”,“$gt”,“$gte”分別對(duì)應(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不僅會(huì)匹配到某個(gè)鍵為null的文檔,也會(huì)匹配不包含這個(gè)鍵的文檔
10、查詢內(nèi)容里邊包含了數(shù)字“1”的博客
db.blogs.find({"content":/1/})
注:只要符合常規(guī)正則表達(dá)式的,都能被MongoDB接受
數(shù)組操作
11、查詢標(biāo)簽里邊既包含“story”,又包含了“rule”的博客
db.blogs.find({"tags":{"$all":["story","rule"]}})
12、查詢第一個(gè)標(biāo)簽是“MongoDB”的博客
db.blogs.find({"tags.0":"MongoDB"})
注:數(shù)組的下標(biāo)是從0開(kāi)始的
13、查詢標(biāo)簽個(gè)數(shù)為3個(gè)的博客
db.blogs.find({"tags":{"$size":3}})
內(nèi)嵌文檔
14、查詢“jack”評(píng)論過(guò)的博客
db.blogs.find({"comment.name":"Jack"})
注:因?yàn)閮?nèi)嵌文檔“.”的問(wèn)題,所以不能使用URL等
15、假設(shè)每頁(yè)2篇博客,按閱讀量倒序,取第二頁(yè)的數(shù)據(jù)
db.blogs.find({}).skip(2).limit(2).sort({"readCount":-1})
注:skip()、limit()、sort(),分別表示略過(guò)文檔的數(shù)量,匹配的數(shù)量和排序(1表示正序,-1表示倒序)
相關(guān)文章
Windows下MongoDB的下載安裝、環(huán)境配置教程圖解
這篇文章主要介紹了Windows下MongoDB的下載安裝、環(huán)境配置教程詳解,本文給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-06-06MongoDB入門教程之C#驅(qū)動(dòng)操作實(shí)例
這篇文章主要介紹了MongoDB入門教程之C#驅(qū)動(dòng)操作實(shí)例,即C#中操作MongoDB數(shù)據(jù)的方法和代碼示例,需要的朋友可以參考下2014-08-08MongoDB特點(diǎn)與體系結(jié)構(gòu)等簡(jiǎn)介
今天小編就為大家分享一篇關(guān)于MongoDB特點(diǎn)與體系結(jié)構(gòu)等簡(jiǎn)介,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧2019-01-01mongodb 實(shí)現(xiàn)遠(yuǎn)程連接
這篇文章主要介紹了mongodb 實(shí)現(xiàn)遠(yuǎn)程連接,需要的朋友可以參考下2014-07-07教你使用mongoose實(shí)現(xiàn)多集合關(guān)聯(lián)查詢
這篇文章主要給大家介紹了關(guān)于如何使用mongoose實(shí)現(xiàn)多集合關(guān)聯(lián)查詢的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-02-02MongoDB的安裝啟動(dòng)及做成windows服務(wù)的教程圖解
這篇文章主要介紹了MongoDB的安裝啟動(dòng)及做成windows服務(wù)的教程圖解,非常不錯(cuò),具有一定的參考借鑒價(jià)值,感興趣的朋友跟隨腳本之家小編一起學(xué)習(xí)吧2018-05-05