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

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

MongoDB各種查詢操作詳解

2020-03-14 13:27:00
字體:
供稿:網(wǎng)友
這篇文章主要介紹了MongoDB各種查詢操作詳解,包括比較查詢、關(guān)聯(lián)查詢、數(shù)組查詢等,需要的朋友可以參考下
 
 

一、find操作

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

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

MongoDB各種查詢操作詳解

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

2、部分查詢

MongoDB各種查詢操作詳解

3、鍵的篩選

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

MongoDB各種查詢操作詳解

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

二、查詢條件

1、比較查詢

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

MongoDB各種查詢操作詳解

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

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

MongoDB各種查詢操作詳解

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

MongoDB各種查詢操作詳解

三、特定類型的查詢

1、null查詢

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

MongoDB各種查詢操作詳解

2、正則表達(dá)式

MongoDB各種查詢操作詳解

3、數(shù)組查詢

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

MongoDB各種查詢操作詳解

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

MongoDB各種查詢操作詳解

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

MongoDB各種查詢操作詳解

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

MongoDB各種查詢操作詳解

四、$where查詢

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

MongoDB各種查詢操作詳解

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

五、游標(biāo)

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

MongoDB各種查詢操作詳解

1、limit,skip和sort

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

MongoDB各種查詢操作詳解

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

包裝查詢:使用sort,limit或skip對(duì)最終結(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í)行那一刻的一致快照,用于避免不一致讀取。

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

 

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

 

3、游標(biāo)內(nèi)幕
看待游標(biāo)的兩種角度:客戶端的游標(biāo)及客戶端游標(biāo)表示的數(shù)據(jù)庫(kù)游標(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)會(huì)向服務(wù)器發(fā)送專門的消息,讓其銷毀游標(biāo)。

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

六、總結(jié)

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


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
国产激情自拍_国产9色视频_丁香花在线电影小说观看 _久久久久国产精品嫩草影院
av在线播放网| 国产三级av在线| 国产精品18久久久久网站| 久久99精品久久久久久野外| 久热精品免费视频| av资源网站在线观看| 人人九九精品| 国产一级黄色| av在线天天| 国产在线一二| 国产经典自拍视频在线观看| 亚洲成人av高清| 五月综合网站| 青青草原av在线| 国产日本韩国在线播放| 亚洲sss视频| 日本中文字幕在线观看| 国产www网站| 国产自产视频| gogo在线高清视频| 国产小视频在线高清播放| 夜色资源网av在先锋网站观看| 天天操人人干| 奇米影视狠狠狠| 国产黄在线看| 国产一区二区三区美女秒播| 青草视频在线播放| 一级二级三级在线观看| 国产激情自拍| 国产区成人精品视频| 高清视频一区二区三区四区| www.综合网.com| 国产不卡精品一区二区三区| 国产毛片视频| 国产在线视频福利| 欧美日韩在线中文字幕| 国产高清在线| 国产黄a三级三级三级av在线看| 免费不卡中文字幕视频| xxxxx中文字幕| 日本高清中文字幕| 日本福利在线| 九色视频网站| 超碰在线影院| 国产中文第一页| 黄色电影网站在线观看| 国产69精品久久app免费版| 青青草中文字幕| 久草在线视频网| 五月伊人六月| 91青青在线视频| 国产丝袜在线| 2019天天操夜夜操| 99热免费观看| 欧美日韩在线视频免费观看| eeuss影影院www在线播放| 日本不卡影院| 国产美女视频一区二区二三区| 午夜视频免费在线观看| 国产亚洲依依| 在线国产中文字幕| 欧美日韩在线中文字幕| 国产中文字幕在线播放| 国产精品入口麻豆免费看| 国产高清视频在线播放| wwwww在线观看免费视频| 四虎成人精品在永久免费| 狠狠干天天干| 伊人久久青青草| 99视频免费| 亚洲综合激情六月婷婷在线观看| 老鸭窝av在线| 91在线超碰| 国产女王在线**视频| 精品视频一二区| 白浆爆出在线观看| 国产人成在线观看| 日本h视频在线观看| 国产一二三区在线| av在线第一页| 国产精品久久久久久精| 亚洲日本伊人| 国产三级在线| 国产麻豆精品入口在线观看| 在线播放www| 国产黄色片在线观看| 激情视频国产| 欧美亚洲系列| 四虎成人欧美精品在永久在线| 国产精品一品| 狠狠插狠狠操| 免费看黄视频网站| 色吊丝av中文字幕| av天天在线| 精品一区二区三区在线观看l| 国产在线高潮| jizz国产| 日本亚洲欧美| www.操操| 牛牛热在线视频| 欧美亚洲系列| 开心激情五月婷婷| 国产有码在线| 天天av天天爱| 国产网站观看9久| 国产婷婷视频在线| 国产野外战在线播放| 最近久乱中文字幕| 国产一卡二卡3卡4卡四卡在线| 国产在线一二三区| 国产午夜在线视频| 国产一级二级在线| 国产成人亚洲综合小说区| 精品无吗乱吗av国产爱色| 精品国内一区二区三区免费视频| 国产www在线观看| av大片在线播放| 日本动漫理论片在线观看网站| a中文在线播放| 久久99国产视频| 国产精品福利视频一区二区三区| 69日小视频在线观看| 亚洲精品白浆| 丁香花在线电影小说观看| 国产羞羞视频| 亚洲男人网站| 欧美成人精品福利网站| 国产一级片在线| av在线天堂| 国产精品视频一区二区久久 | 国产免费高清| 97中文字幕| 国产资源在线看| 中文视频在线| 国产一区二区影视| www.成人.com| 国产对白在线| 国产美女在线观看| 日本福利在线| 伊人免费在线| 99色在线视频| 免费看黄视频网站| 亚洲一本大道| 在线国产一级| 国产激情网址| 天堂资源在线中文| 青青草原国产在线| 在线免费国产视频| 国产夫妻视频| 国产福利在线视频| 国产羞羞视频在线观看| 九九精品九九| 久草视频国产| 国产在线视频网站| 青青草视频免费在线观看| 91亚洲天堂| 中文日本在线观看| 精品欧美日韩一区二区| 国产精品入口麻豆电影| 国产无遮挡又黄又爽免费网站| 国产美女视频一区二区二三区| 欧美性猛交xxxx免费看蜜桃| 日本福利午夜视频在线| 日本一级理论片在线大全| 四虎国产精品永久| www.三级.com| 狠狠综合久久久综合| 天天操天天操天天色天天要| 尤物视频在线看| 国产精品秘入口| 国产无遮挡又黄又爽免费网站| 国产羞羞视频| 伊人免费在线| 九九热视频在线| 国产视频97| 亚洲www色| 国产中文字幕在线| 国产视频二区| av人人综合网| 国产在线一二| 91在线网址| 超碰国产在线观看| 国产精品欧美色图| wwww亚洲| 国产精品理人伦一区二区三区 | 国产亚av手机在线观看| 精品一区二区在线欧美| 免费看成年人视频在线观看| 天天操天天射天天插| 国产精品久久麻豆| 日本h片在线观看| 国产日韩网站| 日本18视频网站| 国产视频精选在线| 日本黄在线观看| 国产欧美一区二区三区小说| jlzzjlzz欧美大全| 精品国产美女福利到在线不卡| 久久精品国产亚洲a∨麻豆| 国产原创在线播放|