一、find操作
MongoDB中使用find來(lái)進(jìn)行查詢(xún),通過(guò)指定find的第一個(gè)參數(shù)可以實(shí)現(xiàn)全部和部分查詢(xún)。
1、查詢(xún)?nèi)?/P>

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

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

查詢(xún)時(shí),數(shù)據(jù)庫(kù)所關(guān)心的查詢(xún)文檔的值必須是常量。
二、查詢(xún)條件
1、比較查詢(xún)
$lt,$lte,$gt,$gte,$ne和,=,>,>=,!=是一一對(duì)應(yīng)的,它們可以組合起來(lái)以查找一個(gè)范圍內(nèi)的值。

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

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

三、特定類(lèi)型的查詢(xún)
1、null查詢(xún)
null不僅能匹配自身,還能匹配鍵不存在的文檔。

2、正則表達(dá)式

3、數(shù)組查詢(xún)
$all:通過(guò)多個(gè)元素來(lái)匹配數(shù)組。

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

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

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

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

$where查詢(xún)需要將每個(gè)文檔從BSON轉(zhuǎn)換為JavaScript對(duì)象,然后通過(guò)$where的表達(dá)式來(lái)運(yùn)行,該過(guò)程不能利用索引,所以查詢(xún)速度較常規(guī)查詢(xún)慢很多。如果必須使用時(shí),可以將常規(guī)查詢(xún)作為前置過(guò)濾,能夠利用索引的話(huà)可以使用索引根據(jù)非$where子句進(jìn)行過(guò)濾,最后使用$where對(duì)結(jié)果進(jìn)行調(diào)優(yōu)。另一種方式采用映射化簡(jiǎn)-MapReduce.
五、游標(biāo)
游標(biāo)是很有用的東西,MongoDB數(shù)據(jù)庫(kù)使用游標(biāo)來(lái)返回find的執(zhí)行結(jié)果??蛻?hù)端使用游標(biāo)可以對(duì)最終結(jié)果進(jìn)行有效的控制,比如分頁(yè),排序。

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

2、高級(jí)查詢(xún)選項(xiàng)
包裝查詢(xún):使用sort,limit或skip對(duì)最終結(jié)果進(jìn)行進(jìn)一步的控制。
有用的配置選項(xiàng):
$maxscan:integer,指定查詢(xún)最多掃描的文檔數(shù)量。
$min:document,查詢(xún)的開(kāi)始條件。
$max:document,查詢(xún)的結(jié)束條件。
$hint:document,指定服務(wù)器使用哪個(gè)索引進(jìn)行查詢(xún)。
$explain:boolean,獲取查詢(xún)執(zhí)行的細(xì)節(jié)(用到的索引,結(jié)果數(shù)量,耗時(shí)等),而并非真正執(zhí)行查詢(xún)。
$snapshot:boolean,確保查詢(xún)的結(jié)果是在查詢(xún)執(zhí)行那一刻的一致快照,用于避免不一致讀取。
包裝查詢(xún)會(huì)將查詢(xún)條件包裝到一個(gè)更大的查詢(xún)文檔中,比如執(zhí)行如下查詢(xún)時(shí):
db.foo.find({"name":"bar"}).sort("x":1)
shell會(huì)把查詢(xún)從{"name":"bar"}轉(zhuǎn)換成{"$query":{"name":"bar"},"$orderby":{"x":1}},而不是直接將{"name":"bar"}作為查詢(xún)文檔發(fā)送給數(shù)據(jù)庫(kù)。
3、游標(biāo)內(nèi)幕
看待游標(biāo)的兩種角度:客戶(hù)端的游標(biāo)及客戶(hù)端游標(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)在客戶(hù)端已不在作用域內(nèi)的情況下,驅(qū)動(dòng)會(huì)向服務(wù)器發(fā)送專(zhuān)門(mén)的消息,讓其銷(xiāo)毀游標(biāo)。
3、超時(shí)銷(xiāo)毀,可以使用immortal函數(shù)關(guān)閉游標(biāo)超時(shí)時(shí)間,采用此操作一定要在迭代完結(jié)果后將游標(biāo)關(guān)閉。
六、總結(jié)
使用MongoDB需要對(duì)文檔結(jié)構(gòu)進(jìn)行合理的設(shè)計(jì),以滿(mǎn)足某些特定需求。比如隨機(jī)選取文檔,使用skip跳過(guò)隨機(jī)個(gè)文檔就沒(méi)有在文檔中加個(gè)隨機(jī)鍵,然后使用某個(gè)隨機(jī)數(shù)對(duì)文檔進(jìn)行查詢(xún)高效,隨機(jī)鍵還能添加索引,效率更高。合理選擇,合理設(shè)計(jì)。
您可能感興趣的文章:- MongoDB常用操作命令大全
- MongoDB中的一些坑(最好不要用)
- MongoDB 語(yǔ)法使用小結(jié)
- Mongodb 忘記密碼的解決辦法
- mongos崩潰后無(wú)法重啟問(wèn)題的解決方法