欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MongoDB各種查詢操作詳解

 更新時(shí)間:2014年03月18日 11:27:48   作者:  
這篇文章主要介紹了MongoDB各種查詢操作詳解,包括比較查詢、關(guān)聯(lián)查詢、數(shù)組查詢等,需要的朋友可以參考下

一、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í)自動清除。

2、游標(biāo)在客戶端已不在作用域內(nèi)的情況下,驅(qū)動會向服務(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ì)。

相關(guān)文章

  • MongoDB日常使用的技巧與注意事項(xiàng)匯總

    MongoDB日常使用的技巧與注意事項(xiàng)匯總

    這篇文章主要給大家總結(jié)介紹了關(guān)于MongoDB日常使用的一些技巧與注意事項(xiàng),文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用MongoDB具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-11-11
  • MongoDB使用profile分析慢查詢的步驟

    MongoDB使用profile分析慢查詢的步驟

    這篇文章主要介紹了MongoDB profile分析慢查詢的示例,幫助大家更好的理解和學(xué)習(xí)使用MongoDB數(shù)據(jù)庫,感興趣的朋友可以了解下
    2021-04-04
  • 淺析MongoDB用戶管理

    淺析MongoDB用戶管理

    mongodb在2.4最新版本中對用戶權(quán)限管理做了全新的調(diào)整,把權(quán)限細(xì)化了,增強(qiáng)了安全性,越來越像mysql的權(quán)限管理了。廢話少說,我們來詳細(xì)看下吧
    2014-08-08
  • 關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題

    關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題

    這篇文章主要介紹了關(guān)于MongoTemplate通過id查詢?yōu)閚ull的問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • MongoDB系列教程(六):java操作mongodb實(shí)例

    MongoDB系列教程(六):java操作mongodb實(shí)例

    這篇文章主要介紹了MongoDB系列教程(六):java操作mongodb實(shí)例,本文講解了java中操作mongodb數(shù)據(jù)增加、刪除、修改、查詢數(shù)據(jù)等代碼實(shí)例,需要的朋友可以參考下
    2015-05-05
  • C#實(shí)現(xiàn)窗體中的各個(gè)控件同比自動放縮大小

    C#實(shí)現(xiàn)窗體中的各個(gè)控件同比自動放縮大小

    這篇文章主要介紹了C#實(shí)現(xiàn)窗體中的各個(gè)控件同比自動放縮大小,實(shí)現(xiàn)方式主要是利用panel控件為主題,對于每個(gè)控件的大小位置和字體這幾個(gè)屬性進(jìn)行記錄,然后根據(jù)窗體改變的大小同時(shí)放縮,需要的朋友可以參考下
    2014-10-10
  • MongoDB的$sample、aggregate和$rand實(shí)現(xiàn)隨機(jī)選取數(shù)據(jù)

    MongoDB的$sample、aggregate和$rand實(shí)現(xiàn)隨機(jī)選取數(shù)據(jù)

    在MongoDB中,我們可以使用內(nèi)置的$sample聚合操作符來隨機(jī)生成數(shù)據(jù),$sample可以從集合文檔中隨機(jī)選擇指定數(shù)量的文檔,但由于其查詢整個(gè)集合的性能問題,應(yīng)該慎用,aggregate方法以及$rand函數(shù)的結(jié)合使用可以實(shí)現(xiàn)更加靈活的查詢操作,并且可以對查詢結(jié)果進(jìn)行精細(xì)篩選
    2024-01-01
  • mongodb replica set 添加刪除節(jié)點(diǎn)的2種方法

    mongodb replica set 添加刪除節(jié)點(diǎn)的2種方法

    replica set多服務(wù)器主從,添加,刪除節(jié)點(diǎn),肯定會經(jīng)常遇到的。下面詳細(xì)說明一下,添加,刪除節(jié)點(diǎn)的2種方法。
    2014-07-07
  • 詳解mongodb搭建Replica Set的方法

    詳解mongodb搭建Replica Set的方法

    這篇文章主要介紹了mongodb搭建Replica Set的方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-12-12
  • MongoDB中的push操作詳解(將文檔插入到數(shù)組)

    MongoDB中的push操作詳解(將文檔插入到數(shù)組)

    $push操作符添加指定的值到數(shù)組中,下面這篇文章主要給大家介紹了關(guān)于MongoDB中push操作(將文檔插入到數(shù)組)的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-11-11

最新評論