国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院

首頁 > 數(shù)據(jù)庫 > MongoDB > 正文

MongoDB各種查詢操作詳解

2020-10-29 18:54:37
字體:
供稿:網(wǎng)友

一、find操作

MongoDB中使用find來進(jìn)行查詢,通過指定find的第一個(gè)參數(shù)可以實(shí)現(xiàn)全部和部分查詢。

1、查詢?nèi)?/P>


空的查詢文檔{}會匹配集合的全部內(nèi)容。如果不指定查詢文檔,默認(rèn)就是{}。

2、部分查詢


3、鍵的篩選

鍵的篩選是查詢時(shí)只返回自己感興趣的鍵值,通過指定find的第二個(gè)參數(shù)來實(shí)現(xiàn)。這樣可以節(jié)省傳輸?shù)臄?shù)據(jù)量,又能節(jié)省客戶端解碼文檔的時(shí)間和內(nèi)存消耗。


查詢時(shí),數(shù)據(jù)庫所關(guān)心的查詢文檔的值必須是常量。

二、查詢條件

1、比較查詢

$lt,$lte,$gt,$gte,$ne和<,<=,>,>=,!=是一一對應(yīng)的,它們可以組合起來以查找一個(gè)范圍內(nèi)的值。


2、關(guān)聯(lián)查詢

$in用于查詢一個(gè)鍵的多個(gè)值,$nin將返回與篩選數(shù)組中所有條件都不匹配的文檔。將$in與$not組合可以實(shí)現(xiàn)$nin相同的效果。


$or用于對多個(gè)鍵做or查詢。


三、特定類型的查詢

1、null查詢

null不僅能匹配自身,還能匹配鍵不存在的文檔。

2、正則表達(dá)式


3、數(shù)組查詢

$all:通過多個(gè)元素來匹配數(shù)組。


$size:查詢指定長度的數(shù)組。


$slice:返回?cái)?shù)組的一個(gè)子集合。


4、內(nèi)嵌文檔查詢


四、$where查詢

$where查詢是MongoDB的高級查詢部分,可以執(zhí)行任意JavaScript作為查詢的一部分,是其他查詢方式的一個(gè)補(bǔ)充。


$where查詢需要將每個(gè)文檔從BSON轉(zhuǎn)換為JavaScript對象,然后通過$where的表達(dá)式來運(yùn)行,該過程不能利用索引,所以查詢速度較常規(guī)查詢慢很多。如果必須使用時(shí),可以將常規(guī)查詢作為前置過濾,能夠利用索引的話可以使用索引根據(jù)非$where子句進(jìn)行過濾,最后使用$where對結(jié)果進(jìn)行調(diào)優(yōu)。另一種方式采用映射化簡-MapReduce.

五、游標(biāo)

游標(biāo)是很有用的東西,MongoDB數(shù)據(jù)庫使用游標(biāo)來返回find的執(zhí)行結(jié)果。客戶端使用游標(biāo)可以對最終結(jié)果進(jìn)行有效的控制,比如分頁,排序。


1、limit,skip和sort

limit:限制結(jié)果數(shù)量,限制的是上限。
skip:略過匹配到的前n個(gè)文檔,然后返回余下的文檔。skip略過過多的文檔時(shí)會產(chǎn)生性能問題,建議盡量避免。
sort:按照指定的鍵對文檔進(jìn)行排序,1為升序,-1為降序。


2、高級查詢選項(xiàng)

包裝查詢:使用sort,limit或skip對最終結(jié)果進(jìn)行進(jìn)一步的控制。

有用的配置選項(xiàng):

$maxscan:integer,指定查詢最多掃描的文檔數(shù)量。
$min:document,查詢的開始條件。
$max:document,查詢的結(jié)束條件。
$hint:document,指定服務(wù)器使用哪個(gè)索引進(jìn)行查詢。
$explain:boolean,獲取查詢執(zhí)行的細(xì)節(jié)(用到的索引,結(jié)果數(shù)量,耗時(shí)等),而并非真正執(zhí)行查詢。
$snapshot:boolean,確保查詢的結(jié)果是在查詢執(zhí)行那一刻的一致快照,用于避免不一致讀取。

包裝查詢會將查詢條件包裝到一個(gè)更大的查詢文檔中,比如執(zhí)行如下查詢時(shí):

db.foo.find({"name":"bar"}).sort("x":1)
shell會把查詢從{"name":"bar"}轉(zhuǎn)換成{"$query":{"name":"bar"},"$orderby":{"x":1}},而不是直接將{"name":"bar"}作為查詢文檔發(fā)送給數(shù)據(jù)庫。

3、游標(biāo)內(nèi)幕
看待游標(biāo)的兩種角度:客戶端的游標(biāo)及客戶端游標(biāo)表示的數(shù)據(jù)庫游標(biāo)(服務(wù)器端)。

在服務(wù)器端,游標(biāo)消耗內(nèi)存和其他資源,所以在合理的情況下需要盡快釋放。服務(wù)器端導(dǎo)致游標(biāo)終止的情況如下:

1、游標(biāo)完成匹配結(jié)果的迭代時(shí)自動(dòng)清除。

2、游標(biāo)在客戶端已不在作用域內(nèi)的情況下,驅(qū)動(dòng)會向服務(wù)器發(fā)送專門的消息,讓其銷毀游標(biāo)。

3、超時(shí)銷毀,可以使用immortal函數(shù)關(guān)閉游標(biāo)超時(shí)時(shí)間,采用此操作一定要在迭代完結(jié)果后將游標(biāo)關(guān)閉。

六、總結(jié)

使用MongoDB需要對文檔結(jié)構(gòu)進(jìn)行合理的設(shè)計(jì),以滿足某些特定需求。比如隨機(jī)選取文檔,使用skip跳過隨機(jī)個(gè)文檔就沒有在文檔中加個(gè)隨機(jī)鍵,然后使用某個(gè)隨機(jī)數(shù)對文檔進(jìn)行查詢高效,隨機(jī)鍵還能添加索引,效率更高。合理選擇,合理設(shè)計(jì)。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
国产日本视频| 国产免费高清| 国产精品视频一区二区免费不卡| 六月天色婷婷| 五月天婷婷基地| 国产超碰在线| аⅴ成人天堂中文在线| 懂色av一区| 国产精品蜜臀| 日本欧美在线视频免费观看| 国产综合视频一区二区三区免费| 在线观看精品一区二区三区| 影音先锋在线中文字幕| 夜夜操天天干| **三级三级97片毛片| 国产黄色在线播放| eeuss影院在线| 国产麻豆一区二区三区精品| 国产成人精品久久一区二区小说 | 中文字幕av在线播放| av影视在线看| 国产精品一品| 在线观看av网站永久| 国产网站免费观看| 另类专区欧美| 亚洲人成电影| 国产色视频网站| 国产在线视频精品视频免费看| 69国产精品视频| 国产日本视频| 中文字幕麻豆| 好看的中文字幕在线播放| 亚洲成人av在线影院| 国产黄色免费| 国产98在线| 国产黄色免费看| 国产极品美女到高潮| 伊人永久在线| 9999在线视频| 国产福利免费观看| 国产精品久久久精品a级小说| 久热精品免费视频| www.国产精品.com| 小说区乱图片区| 中文天堂av| 精品推荐蜜桃传媒| 91蜜桃在线视频| 精品偷拍激情视频在线观看| 国产精品久久久久白浆| 国产丝袜精品丝袜| 国产精品久久一区二区三区不卡| 中文字幕在线视频免费观看| 日本一二三区视频免费高清| 性网站在线播放| 看成年女人免费午夜视频| jizz性欧美| 久久亚洲国产成人亚| 国产中文字幕网| 中文字幕在线免费观看| 国产精品久久精品牛牛影视| 精品视频二区| 九九热视频在线观看| 最新中文字幕av专区| 国产视频中文字幕| 在线视频观看亚洲| 黄色片免费在线| 中文视频在线| 免费的黄网站在线观看| 国产女人在线视频| 国产啊啊啊视频在线观看| 天天干天天摸| 国产精品18久久久久久久久久| 91国内在线| 国产一级黄色电影| www中文字幕在线观看| 国产三级av在线| 青青草免费在线视频| 国产激情三区| 国产卡1卡2卡三卡在线| av麻豆国产| 国产不卡在线| 国产私人影院| 男人天堂亚洲| 在线a人片免费观看视频| 国产在线一二| www.三级.com| av在线官网| 99re热视频在线| 国产极品嫩模在线视频一区| 久久久久久91精品色婷婷| 国产黄色在线网站| 国产一区二区三区不卡在线| 青青草原av在线| av日韩在线免费| 精品麻豆视频| 国产福利在线| 一色桃子av在线| 91九色在线看| 91欧洲在线视精品在亚洲| 国产视频一二| 国产二区视频在线观看| 国产精品jvid在线观看| 国产欧美久久久久久久久| 国产精品自产拍在线观看2019| 欧美精品日韩少妇| 激情在线视频播放| 国产在线看片| 国产香蕉视频在线看| 国产污污在线观看| 2021天堂中文幕一二区在线观| 精品无人乱码| 亚洲电影视频在线| 日本久久网站| 国内外激情在线| 国产精品xxx电影| 亚洲大香人伊一本线| www.香蕉视频在线观看| 欧美啪啪精品| 国产黄网站在线观看| 青青草原国产在线观看| 丁香在线视频| 国产三级自拍| 日本在线观看| 国产日韩网站| 免费网站看黄yyy222| 国产午夜在线| 欧洲亚洲精品视频| 午夜伦全在线观看| 制服丝袜中文字幕在线观看| 九九精品视频在线观看九九| 国产天堂资源| 玖玖在线视频| 亚洲字幕成人中文在线观看| 91av久久| 欧美日韩在线精品成人综合网| 国产一级在线| 国产在线视精品麻豆| av免费在线观看网站| 中文字幕免费中文| 天天干天天摸| 99久热re在线精彩视频| 天堂在线亚洲| а√天堂8资源在线官网| 国产高清av| 最近中文字幕mv免费高清视频8| 99在线播放| 中文av在线播放| 国产精品入口麻豆免费看| 欧美在线中文| 免费a级毛片在线观看| av日韩在线免费| 精品视频一区二区观看| 国产视频在线播放| 国产女王在线**视频| www免费在线观看视频| 国产精品人人爱一区二区白浆| 超碰免费在线观看| www.99av| 香蕉视频网站在线播放| 99reav| 在线中文字幕av| 精精国产xxxx视频在线中文版 | 中文字幕有码在线视频| 开心快乐六月丁香婷婷| 天天干天天摸| www.九九热.com| 免费国产视频| 久久久久久久久亚洲精品| 久草在线资源福利| 国产另类图片| 国产午夜精品一区理论片| 国产网站在线播放| 精品女厕厕露p撒尿| 中文乱码字幕av网站| 青青久在线视频免费观看| 久草国产视频| 国产一二区在线| 亚洲天堂电影在线观看| 成年黄网站在线观看免费| 91xxx在线观看| 国产欧美黑人| 亚洲最新永久观看在线| 一本大道久久精品| 国产中文字幕在线| 91亚洲欧美| 国产麻豆麻豆| 精精国产xxxx视频在线| 老师我好爽再深一点的视频| 国产一级电影网| 在线黄色av| 国产视频1区| 免费特级黄毛片| 国产高清视频免费最新在线| h网站久久久| 国产黄色高清在线| 久热中文字幕| 亚洲欧美日韩成人网| 九九免费视频| av在线播放网| 在线中文字幕视频|