a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 數據庫 > MongoDB > 正文

MongoDB各種查詢操作詳解

2020-03-14 13:27:00
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了MongoDB各種查詢操作詳解,包括比較查詢、關聯查詢、數組查詢等,需要的朋友可以參考下
 
 

一、find操作

MongoDB中使用find來進行查詢,通過指定find的第一個參數可以實現全部和部分查詢。

1、查詢全部

MongoDB各種查詢操作詳解

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

2、部分查詢

MongoDB各種查詢操作詳解

3、鍵的篩選

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

MongoDB各種查詢操作詳解

查詢時,數據庫所關心的查詢文檔的值必須是常量。

二、查詢條件

1、比較查詢

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

MongoDB各種查詢操作詳解

2、關聯查詢

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

MongoDB各種查詢操作詳解

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

MongoDB各種查詢操作詳解

三、特定類型的查詢

1、null查詢

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

MongoDB各種查詢操作詳解

2、正則表達式

MongoDB各種查詢操作詳解

3、數組查詢

$all:通過多個元素來匹配數組。

MongoDB各種查詢操作詳解

$size:查詢指定長度的數組。

MongoDB各種查詢操作詳解

$slice:返回數組的一個子集合。

MongoDB各種查詢操作詳解

4、內嵌文檔查詢

MongoDB各種查詢操作詳解

四、$where查詢

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

MongoDB各種查詢操作詳解

$where查詢需要將每個文檔從BSON轉換為JavaScript對象,然后通過$where的表達式來運行,該過程不能利用索引,所以查詢速度較常規查詢慢很多。如果必須使用時,可以將常規查詢作為前置過濾,能夠利用索引的話可以使用索引根據非$where子句進行過濾,最后使用$where對結果進行調優。另一種方式采用映射化簡-MapReduce.

五、游標

游標是很有用的東西,MongoDB數據庫使用游標來返回find的執行結果。客戶端使用游標可以對最終結果進行有效的控制,比如分頁,排序。

MongoDB各種查詢操作詳解

1、limit,skip和sort

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

MongoDB各種查詢操作詳解

2、高級查詢選項

包裝查詢:使用sort,limit或skip對最終結果進行進一步的控制。

有用的配置選項:

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

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

 

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

 

3、游標內幕
看待游標的兩種角度:客戶端的游標及客戶端游標表示的數據庫游標(服務器端)。

在服務器端,游標消耗內存和其他資源,所以在合理的情況下需要盡快釋放。服務器端導致游標終止的情況如下:

1、游標完成匹配結果的迭代時自動清除。

2、游標在客戶端已不在作用域內的情況下,驅動會向服務器發送專門的消息,讓其銷毀游標。

3、超時銷毀,可以使用immortal函數關閉游標超時時間,采用此操作一定要在迭代完結果后將游標關閉。

六、總結

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


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 久久国产欧美日韩精品 | 久久黄色网 | 国产欧美日韩中文字幕 | 在线99热 | 亚洲黄色一区二区 | 综合久久国产九一剧情麻豆 | 国产日韩欧美一区二区在线观看 | 亚洲欧美在线综合 | 日韩中文字幕一区二区 | 精品国产一区二区三区久久影院 | 国产精品毛片 | 国产成人精品久久二区二区 | 欧美精品一区二区三区在线四季 | 中文字幕 国产 | 成人在线h| 亚洲欧美在线一区 | 精品福利av导航 | 久久精品久久精品国产大片 | 久久男女视频 | 日韩黄视频 | 在线播放黄色片网站 | 成人在线免费观看 | 精品无人乱码一区二区三区 | 色婷婷综合久久久久中文一区二 | 亚州中文字幕蜜桃视频 | 国产精品99精品久久免费 | 国产精品久久久久久亚洲调教 | 日本在线观看视频一区 | 精品视频一区二区 | 久久99精品久久久水蜜桃 | 久久久精品国产 | 国产高清精品一区 | 在线播放黄 | 操皮视频 | 亚洲国产精品一区 | 91国自产区一二三区 | 成人免费crm在线观看 | 日韩精品视频免费专区在线播放 | 久久人人网 | 欧美一区二区三区视频 | 精品久久一区二区三区 |