MongoDB 的使用總結(jié) 使用條件判斷 if...then...else...

mongodb 使用條件判斷 if...then...else...

mongodb if判斷的結(jié)構(gòu)如下

{
    "$cond": {
        "if": {
            "<判斷條件>"
        },
        "then": "",
        "else": {
            // 嵌套查詢
            "$cond": {}
        }
    }
}

mongodb if判斷示例

// 構(gòu)造測(cè)試數(shù)據(jù)
db.col00.insertMany([
    {"name": "doc01", "age": 10},
    {"name": "doc02", "age": 11},
    {"name": "doc03", "age": 12},
    {"name": "doc03", "age": 20},
    {"name": "doc04", "age": 21},
    {"name": "doc05", "age": 22},
    {"name": "doc07", "age": 30},
    {"name": "doc08", "age": 31},
    {"name": "doc09", "age": 32}
]);

// 使用場(chǎng)景:針對(duì)測(cè)試數(shù)據(jù),要實(shí)現(xiàn)對(duì)年齡(age)按區(qū)間進(jìn)行分組聚合  
// 注意點(diǎn):$$ROOT表示文檔自身
db.col00.aggregate([
    {
        "$project": {
            "self": "$$ROOT",
            "ageKey": {
                "$cond": {
                    "if": {
                        "$lt": [
                            "$age",
                            20
                        ]
                    },
                    "then": "0~20歲",
                    "else": {
                        "$cond": {
                            "if": {
                                "$and": [
                                    {
                                        "$gte": ["$age", 20]
                                    },
                                    {
                                        "$lt": ["$age", 30]
                                    }
                                ]
                            },
                            "then": "20~30歲",
                            "else": "30歲以上"
                        }
                    }
                }
            }
        }
    },
    {
        "$group": {
            "_id": "$ageKey",
            "count": {
                "$sum": 1
            },
            "docs": {
                "$push": "$self"
            }
        }
    }
])

mongodb if判斷示例 執(zhí)行結(jié)果如下


示例執(zhí)行結(jié)果
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末讯沈,一起剝皮案震驚了整個(gè)濱河市杆烁,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 221,695評(píng)論 6 515
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異广辰,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)主之,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 94,569評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門择吊,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人槽奕,你說(shuō)我怎么就攤上這事几睛。” “怎么了粤攒?”我有些...
    開封第一講書人閱讀 168,130評(píng)論 0 360
  • 文/不壞的土叔 我叫張陵所森,是天一觀的道長(zhǎng)囱持。 經(jīng)常有香客問(wèn)我,道長(zhǎng)焕济,這世上最難降的妖魔是什么纷妆? 我笑而不...
    開封第一講書人閱讀 59,648評(píng)論 1 297
  • 正文 為了忘掉前任,我火速辦了婚禮晴弃,結(jié)果婚禮上掩幢,老公的妹妹穿的比我還像新娘。我一直安慰自己肝匆,他們只是感情好粒蜈,可當(dāng)我...
    茶點(diǎn)故事閱讀 68,655評(píng)論 6 397
  • 文/花漫 我一把揭開白布顺献。 她就那樣靜靜地躺著旗国,像睡著了一般。 火紅的嫁衣襯著肌膚如雪注整。 梳的紋絲不亂的頭發(fā)上能曾,一...
    開封第一講書人閱讀 52,268評(píng)論 1 309
  • 那天,我揣著相機(jī)與錄音肿轨,去河邊找鬼寿冕。 笑死,一個(gè)胖子當(dāng)著我的面吹牛椒袍,可吹牛的內(nèi)容都是我干的驼唱。 我是一名探鬼主播,決...
    沈念sama閱讀 40,835評(píng)論 3 421
  • 文/蒼蘭香墨 我猛地睜開眼驹暑,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼玫恳!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起优俘,我...
    開封第一講書人閱讀 39,740評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤京办,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后帆焕,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體惭婿,經(jīng)...
    沈念sama閱讀 46,286評(píng)論 1 318
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,375評(píng)論 3 340
  • 正文 我和宋清朗相戀三年叶雹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了财饥。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,505評(píng)論 1 352
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡折晦,死狀恐怖钥星,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情筋遭,我是刑警寧澤打颤,帶...
    沈念sama閱讀 36,185評(píng)論 5 350
  • 正文 年R本政府宣布暴拄,位于F島的核電站,受9級(jí)特大地震影響编饺,放射性物質(zhì)發(fā)生泄漏乖篷。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,873評(píng)論 3 333
  • 文/蒙蒙 一透且、第九天 我趴在偏房一處隱蔽的房頂上張望撕蔼。 院中可真熱鬧,春花似錦秽誊、人聲如沸鲸沮。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,357評(píng)論 0 24
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)讼溺。三九已至,卻和暖如春最易,著一層夾襖步出監(jiān)牢的瞬間怒坯,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,466評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工藻懒, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留剔猿,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 48,921評(píng)論 3 376
  • 正文 我出身青樓嬉荆,卻偏偏與公主長(zhǎng)得像归敬,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子鄙早,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,515評(píng)論 2 359

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