MongoDB查詢知多少

查詢選擇器

<b>最簡(jiǎn)單的查詢語(yǔ)句:</b>

db.customers.find();

這種查詢語(yǔ)句會(huì)按照插入的順序返回前20個(gè)文檔苛吱。如果需要顯示更多的話吹泡,只需按下"lt"命令就可以顯示更多的文檔了骤星。

<b>精確匹配選擇器:</b>

db.customers.find({id:6});
db.customers.find({id:6,name:"name 1",age:101});

根據(jù)指定的字段查詢文檔,這種查詢方式稱為精確匹配選擇器爆哑。

<b>$lt表示的是小于:</b>

db.customers.find({id:{$lt:10}});

<b>$lte表示的是小于或者等于:</b>

db.customers.find({id:{$lte:6});

<b>$gt表示的是大于:</b>

db.customers.find({id:{$gt:1});

<b>$gte表示的是大于或等于:</b>

    db.customers.find({id:{$gte:3}});

<b>范圍選擇器:</b>

db.customers.find({age:{$lt:120,$gte:112});

該查詢語(yǔ)句表示小于120,大于或等于112洞难。

db.customers.find({id:{$in:[1,2]}});

$in表示返回的key的值在某些value范圍內(nèi)。

db.customers.find({id:{$nin:[1,2]}});

$nin表示返回的key的值不在某些范圍之內(nèi),這種查詢效率非常低揭朝,因?yàn)樗鼤?huì)對(duì)全表進(jìn)行掃描操作队贱。

db.customers.find({id:{$ne:1}});

$ne表示的是不等于。單獨(dú)使用$ne它也不會(huì)使用索引的優(yōu)勢(shì)潭袱,反而會(huì)進(jìn)行全表掃描柱嫌,我們最好與其它選擇器配合使用,以便發(fā)揮最大的查詢性能屯换。

db.customers.find({$or:[{id:2},{id:3}]});

$or表示或運(yùn)算的選擇器,主要用于對(duì)兩個(gè)不同的key對(duì)應(yīng)的文檔進(jìn)行連接编丘。

db.customers.find({$and:[{id:2},{age:111}]});

$and表示與預(yù)算的選擇器,主要用于對(duì)兩個(gè)不同的key要同時(shí)滿足條件。

db.customers.find({$exists:false});

$exists與關(guān)系數(shù)據(jù)庫(kù)中的exists不一樣彤悔,因?yàn)镸ongoDB的表結(jié)構(gòu)不固定嘉抓,有時(shí)候需要返回包含某個(gè)字段的所有記錄或者不包含某個(gè)字段的所有記錄,$exists這時(shí)就可以派上用場(chǎng)了晕窑。當(dāng)然你還可以使用備用查詢操作方法:db.customers.find({id:null});

查詢投射

在我們進(jìn)行查詢的時(shí)候抑片,有時(shí)我們需要對(duì)返回的結(jié)果集進(jìn)行進(jìn)一步的處理,如只需要返回指定的字段杨赤,此時(shí)查詢投射項(xiàng)就可以發(fā)揮它的功效了敞斋,下面我們逐一剖析。

db.customers.find({'detail.1.post':5},{_id:0,id:1,name:1});

此條語(yǔ)句執(zhí)行的結(jié)果就是按照條件'detail.1.post':5來(lái)返回結(jié)果集疾牲,但是只顯示id和name兩個(gè)字段哦植捎,同時(shí)過濾默認(rèn)生成字段_id。

db.customers.find().sort({id:-1});

對(duì)查詢的結(jié)果集按照id的降序進(jìn)行排序后返回说敏。(ps:建立索引能提高查詢速度)鸥跟。

db.customers.find({}).skip(5).limit(5).sort({id:-1});

此條語(yǔ)句執(zhí)行的過程是先對(duì)結(jié)果集進(jìn)行排序丢郊,然后跳過5行盔沫,然后從這個(gè)位置返回接下的5行医咨。(ps:如果skip的參數(shù)過大,那么查詢語(yǔ)句將會(huì)掃描大量的文檔架诞,這樣執(zhí)行性能將會(huì)很低下拟淮。因此查詢盡量不要用skip,用其它方式來(lái)代替skip的操作)谴忧。

數(shù)組操作

db.customers.find({'detail.1.post':5},{_id:0,id:1,name:1});

投射選項(xiàng){_id:0,name:1}針對(duì)的值是簡(jiǎn)單類型很泊,包括查詢選擇器也是嵌套文檔,可以通過操作符"."一點(diǎn)點(diǎn)嵌套進(jìn)去沾谓,如果值為數(shù)組類型并且數(shù)組的元素又是文檔類型委造,查詢語(yǔ)句將會(huì)有所改變。
假如有如下結(jié)構(gòu)數(shù)據(jù):

{
  "_id":1,
  "name":"車",
 "brand":"大眾","寶馬","奔馳","別克","東風(fēng)悅達(dá)起亞"
}
1.精確匹配數(shù)組值

我們可以通過簡(jiǎn)單的精確匹配得到某條記錄均驶,如以下語(yǔ)句所示昏兆。

db.cars.find({"brand":["大眾","寶馬","奔馳"]});
2.匹配數(shù)組中的一個(gè)值

假如數(shù)組有多個(gè)元素,只要這些元素中包含有這個(gè)值妇穴,就會(huì)返回這條文檔爬虱,如下所示。

db.cars.find({"brand":"大眾"});

假如此時(shí)集合中有兩條記錄,則返回值中兩條記錄都會(huì)存在腾它。

3.配置指定位置的元素值
db.cars.find({"brand.0":"大眾"});
4.指定數(shù)組索引并匹配嵌套文檔中的字段值
{
  "_id":1,
  "StatusInfo":[
    {
      "status":9,
      "desc":"已取消"
    },
    {
      "status":2,
      "desc":"已付款"
    }
  ]
}

字段"StatusInfo"是一個(gè)嵌套文檔的數(shù)組跑筝。

db.Order.find({"StatusInfo.0.status":2});

返回?cái)?shù)組中索引0處且嵌套文檔中status值為2的所有文檔。

總結(jié)

通過學(xué)習(xí)MongoDB的查詢操作符瞒滴,我們可以根據(jù)自己的業(yè)務(wù)來(lái)查詢自己所要查詢的內(nèi)容曲梗,但是在建立查詢的時(shí)候千萬(wàn)不要忘記文中所提及的ps哦,加入索引能提高查詢速度妓忍,這是一種以空間換時(shí)間的方法稀并,所以要掌握MongoDB的查詢操作就是在實(shí)際中不斷去積累。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末单默,一起剝皮案震驚了整個(gè)濱河市碘举,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌搁廓,老刑警劉巖引颈,帶你破解...
    沈念sama閱讀 211,639評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異境蜕,居然都是意外死亡蝙场,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,277評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門粱年,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)售滤,“玉大人,你說我怎么就攤上這事⊥曷幔” “怎么了赐俗?”我有些...
    開封第一講書人閱讀 157,221評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)弊知。 經(jīng)常有香客問我阻逮,道長(zhǎng),這世上最難降的妖魔是什么秩彤? 我笑而不...
    開封第一講書人閱讀 56,474評(píng)論 1 283
  • 正文 為了忘掉前任叔扼,我火速辦了婚禮,結(jié)果婚禮上漫雷,老公的妹妹穿的比我還像新娘瓜富。我一直安慰自己,他們只是感情好降盹,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,570評(píng)論 6 386
  • 文/花漫 我一把揭開白布食呻。 她就那樣靜靜地躺著,像睡著了一般澎现。 火紅的嫁衣襯著肌膚如雪仅胞。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,816評(píng)論 1 290
  • 那天剑辫,我揣著相機(jī)與錄音干旧,去河邊找鬼。 笑死妹蔽,一個(gè)胖子當(dāng)著我的面吹牛椎眯,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播胳岂,決...
    沈念sama閱讀 38,957評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開眼编整,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了乳丰?” 一聲冷哼從身側(cè)響起掌测,我...
    開封第一講書人閱讀 37,718評(píng)論 0 266
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎产园,沒想到半個(gè)月后汞斧,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,176評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡什燕,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,511評(píng)論 2 327
  • 正文 我和宋清朗相戀三年粘勒,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片屎即。...
    茶點(diǎn)故事閱讀 38,646評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡庙睡,死狀恐怖事富,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情乘陪,我是刑警寧澤统台,帶...
    沈念sama閱讀 34,322評(píng)論 4 330
  • 正文 年R本政府宣布,位于F島的核電站暂刘,受9級(jí)特大地震影響饺谬,放射性物質(zhì)發(fā)生泄漏捂刺。R本人自食惡果不足惜谣拣,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,934評(píng)論 3 313
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望族展。 院中可真熱鬧森缠,春花似錦、人聲如沸仪缸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,755評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)恰画。三九已至宾茂,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間拴还,已是汗流浹背跨晴。 一陣腳步聲響...
    開封第一講書人閱讀 31,987評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留片林,地道東北人端盆。 一個(gè)月前我還...
    沈念sama閱讀 46,358評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像费封,于是被迫代替她去往敵國(guó)和親焕妙。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,514評(píng)論 2 348

推薦閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理弓摘,服務(wù)發(fā)現(xiàn)焚鹊,斷路器,智...
    卡卡羅2017閱讀 134,633評(píng)論 18 139
  • 1. 簡(jiǎn)介 1.1 什么是 MyBatis 韧献? MyBatis 是支持定制化 SQL寺旺、存儲(chǔ)過程以及高級(jí)映射的優(yōu)秀的...
    笨鳥慢飛閱讀 5,454評(píng)論 0 4
  • 目錄 查詢操作 集合查詢方法 find() 查詢內(nèi)嵌文檔 查詢操作符(內(nèi)含 數(shù)組查詢) "$gt" 、"$gte"...
    彩虹之夢(mèng)閱讀 1,015評(píng)論 0 1
  • 1 在四線城市工作了一年的朋友璐璐來(lái)北京工作了陈莽,公司地址在五道口,她住在通州,周末來(lái)朝陽(yáng)區(qū)找我吃飯走搁。 在A鎮(zhèn)長(zhǎng)大独柑,...
    七天路過閱讀 577評(píng)論 0 2
  • 路在何方(312) ■珍珍花露 風(fēng)來(lái)得太早了 打亂了我的思路 小雨沙沙的下 困惑了我好久 路在哪里 ...
    朝花夕拾杯中酒123閱讀 162評(píng)論 0 15