AggregateCommand.isArray(value: Expression): Object

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

聚合操作符。判断给定表达式是否是数组,返回布尔值。

参数

value: Expression

表达式

返回值

Object

API 说明

语法如下:

  1. db.command.aggregate.isArray(<expression>)

参数可以是任意表达式。

示例代码

假设集合 stats 有如下记录:

  1. {
  2. "_id": 1,
  3. "base": 10,
  4. "sales": [ 1, 6, 2, 2, 5 ]
  5. }
  6. {
  7. "_id": 2,
  8. "base": 1,
  9. "sales": 100
  10. }

计算总销量,如果 sales 是数字,则求 sales * base,如果 sales 是数组,则求数组元素之和与 base 的乘积。

  1. const $ = db.command.aggregate
  2. db.collection('stats').aggregate()
  3. .project({
  4. sum: $.cond({
  5. if: $.isArray('$sales'),
  6. then: $.multiply([$.sum(['$sales']), '$base']),
  7. else: $.multiply(['$sales', '$base']),
  8. })
  9. })
  10. .end()

返回结果如下:

  1. { "_id": 1, "index": 160 }
  2. { "_id": 2, "index": 100 }