SDK数据库 Aggregate指定根节点


本文整理自网络,侵删。

Aggregate.replaceRoot(object:Object): Aggregate

支持端:小程序 2.7.4, 云函数 0.8.1, Web

聚合阶段。指定一个已有字段作为输出的根节点,也可以指定一个计算出的新字段作为根节点。

参数

object: Object

返回值

Aggregate

API 说明

replaceRoot 使用形式如下:

replaceRoot({
    newRoot: <表达式>
})

表达式格式如下:

格式说明
<字段名>指定一个已有字段作为输出的根节点(如果字段不存在则报错
<对象>计算一个新字段,并且把这个新字段作为根节点

示例

使用已有字段作为根节点

假设我们有一个 schools 集合,内容如下:

{
  "_id": 1,
  "name": "SFLS",
  "teachers": {
    "chinese": 22,
    "math": 18,
    "english": 21,
    "other": 123
  }
}

下面的代码使用 replaceRoot,把 teachers 字段作为根节点输出:

db.collection('schools')
  .aggregate()
  .replaceRoot({
    newRoot: '$teachers'
  })
  .end()

输出如下:

{
  "chinese": 22,
  "math": 18,
  "english": 21,
  "other": 123
}

使用计算出的新字段作为根节点

假设我们有一个 roles 集合,内容如下:

{ "_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": "张牧之" }



标签:微信小程序

相关阅读 >>

微信小程序表单组件单选框 radio

微信小程序api 发送客服消息

微信小程序 变量

微信小程序api 画面录制器-创建webgl画面录制器

微信小程序api 音频-开始播放

微信小程序 api

微信小程序 weui基础组件

微信小程序api nfc-监听接受消息事件

微信小程序设计规范(1) 友好礼貌

微信小程序api 绘图导出图片canvastotempfilepath(object)

更多相关阅读请进入《微信小程序》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...