W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗(yàn)值獎勵
支持端:小程序 2.7.4, 云函數(shù) 0.8.1, Web
聚合階段。指定一個(gè)已有字段作為輸出的根節(jié)點(diǎn),也可以指定一個(gè)計(jì)算出的新字段作為根節(jié)點(diǎn)。
replaceRoot 使用形式如下:
replaceRoot({
newRoot: <表達(dá)式>
})
表達(dá)式格式如下:
格式 | 說明 |
---|---|
<字段名> | 指定一個(gè)已有字段作為輸出的根節(jié)點(diǎn)(如果字段不存在則報(bào)錯(cuò)) |
<對象> | 計(jì)算一個(gè)新字段,并且把這個(gè)新字段作為根節(jié)點(diǎn) |
假設(shè)我們有一個(gè) schools 集合,內(nèi)容如下:
{
"_id": 1,
"name": "SFLS",
"teachers": {
"chinese": 22,
"math": 18,
"english": 21,
"other": 123
}
}
下面的代碼使用 replaceRoot,把 teachers 字段作為根節(jié)點(diǎn)輸出:
db.collection('schools')
.aggregate()
.replaceRoot({
newRoot: '$teachers'
})
.end()
輸出如下:
{
"chinese": 22,
"math": 18,
"english": 21,
"other": 123
}
假設(shè)我們有一個(gè) roles 集合,內(nèi)容如下:
{ "_id": 1, "first_name": "四郎", "last_name": "黃" }
{ "_id": 2, "first_name": "邦德", "last_name": "馬" }
{ "_id": 3, "first_name": "牧之", "last_name": "張" }
下面的代碼使用 replaceRoot,把 first_name 和 last_name 拼在一起:
const { concat } = db.command.aggregate
db.collection('roles')
.aggregate()
.replaceRoot({
newRoot: {
full_name: concat(['$last_name', '$first_name'])
}
})
.end()
輸出如下:
{ "full_name": "黃四郎" }
{ "full_name": "馬邦德" }
{ "full_name": "張牧之" }
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報(bào)電話:173-0602-2364|舉報(bào)郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: