日韩小视频-日韩久久一区二区三区-日韩久久一级毛片-日韩久久久精品中文字幕-国产精品亚洲精品影院-国产精品亚洲欧美云霸高清

下載吧 - 綠色安全的游戲和軟件下載中心

軟件下載吧

當(dāng)前位置:軟件下載吧 > 數(shù)據(jù)庫 > DB2 > MongoDB各種查詢操作詳解

MongoDB各種查詢操作詳解

時間:2024-03-04 00:33作者:下載吧人氣:30

一、find操作


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


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



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


2、部分查詢




3、鍵的篩選


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




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


二、查詢條件


1、比較查詢


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




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


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




$or用于對多個鍵做or查詢。




三、特定類型的查詢


1、null查詢


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



2、正則表達(dá)式




3、數(shù)組查詢


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




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




$slice:返回數(shù)組的一個子集合。




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




四、$where查詢


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




$where查詢需要將每個文檔從BSON轉(zhuǎn)換為JavaScript對象,然后通過$where的表達(dá)式來運行,該過程不能利用索引,所以查詢速度較常規(guī)查詢慢很多。如果必須使用時,可以將常規(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個文檔,然后返回余下的文檔。skip略過過多的文檔時會產(chǎn)生性能問題,建議盡量避免。
sort:按照指定的鍵對文檔進(jìn)行排序,1為升序,-1為降序。




2、高級查詢選項


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


有用的配置選項:


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


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



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é)果的迭代時自動清除。


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


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


六、總結(jié)


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


標(biāo)簽MongoDB,各種,查詢,操作,詳解

相關(guān)下載

查看所有評論+

網(wǎng)友評論

網(wǎng)友
您的評論需要經(jīng)過審核才能顯示

熱門閱覽

最新排行

公眾號

主站蜘蛛池模板: 亚洲一区二区三区在线 | 国产乱码精品一区二区三区卡 | 成人毛片一区二区三区 | 美女wc | 日韩精品欧美国产精品亚 | 99热播 | 美女又黄又免费的视频 | 亚洲国产精品久久久久久网站 | 久色免费视频 | 亚洲网址在线观看 | xh98hx国产在线视频 | 黄免费看| 一区二区三区四区视频在线 | 50岁老女人毛片一级亚洲 | 九九久久久 | 成 人 动漫在线观看网站网站 | 久草高清视频 | 国产的一级毛片完整 | 国产综合视频在线观看一区 | 91年精品国产福利线观看久久 | 91青青国产在线观看免费 | 精品九九视频 | 羞羞一区二区三区四区片 | 国产va免费精品高清在线观看 | 小屁孩cao大人免费网站 | 国内精品a | 毛片看看| 100000免费啪啪18免进 | 精品特级一级毛片免费观看 | 美女又黄又免费的视频 | 一级爱做片免费观看久久 | 亚洲综合色一区二区三区另类 | 成人a免费α片在线视频网站 | 久久久久亚洲日日精品 | 国产妇乱子伦视频免费 | 国产在线欧美日韩精品一区二区 | 美女黄页黄频 | 国产成人免费视频 | 久草热久草在线 | 三级网址在线 | 日韩中文字幕在线亚洲一区 |