$mul (字段更新运算符)

适用对象: MongoDB vCore

运算符 $mul 将字段的值乘以指定数字。 如果该字段不存在, $mul 则创建该字段并将其设置为零。 此运算符可用于对数值字段应用百分比更改、缩放值或执行批量计算。

语法

$mul 运算符的语法如下所示:

{
  $mul: {
    <field1>: <number1>,
    <field2>: <number2>,
    ...
  }
}

参数

DESCRIPTION
field 要相乘的字段的名称。
number 要乘以字段值的数字。 必须是数值。

示例:

让我们了解 stores 数据集中的示例 json 的用法。

{
  "_id": "438db151-04b8-4422-aa97-acf94bc69cfc",
  "name": "Fourth Coffee | Turntable Boutique - Tromptown",
  "staff": {
    "totalStaff": {
      "fullTime": 8,
      "partTime": 5
    }
  },
  "sales": {
    "totalSales": 24863,
    "salesByCategory": [
      {
        "categoryName": "Direct-Drive Turntables",
        "totalSales": 24863
      }
    ]
  }
}

示例 1:应用百分比增加

对总销售额应用 10 个% 增加(乘以 1.1)。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "sales.totalSales": 1.1
    }
  }
)

totalSales这将从 24863 更改为 27349.3(24863 × 1.1)。

示例 2:应用折扣

对销售数据应用 20% 折扣(乘以 0.8)。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "sales.totalSales": 0.8
    }
  }
)

示例 3:多个字段作

同时将不同的乘数应用于多个字段。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "staff.totalStaff.fullTime": 1.5,
      "staff.totalStaff.partTime": 2,
      "sales.totalSales": 1.25
    }
  }
)

这将:

  • 从 8 增加到 fullTime 12 (8 × 1.5)
  • 从 5 增加到 partTime 10 (5 × 2)
  • 增加 totalSales 25% (乘以 1.25)

示例 4:创建新字段

如果字段不存在, $mul 请创建它并将其设置为 0。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "sales.bonusPoints": 100,
      "staff.overtimeHours": 40
    }
  }
)

bonusPoints同时创建值为 0 的两者overtimeHours

示例 5:使用小数

对财务计算应用精确的十进制乘数。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "sales.totalSales": 0.915
    }
  }
)

示例 6:更新数组元素

使用位置运算符将乘数应用于数组中的特定元素。

db.stores.updateOne(
  {
    "_id": "438db151-04b8-4422-aa97-acf94bc69cfc",
    "sales.salesByCategory.categoryName": "Direct-Drive Turntables"
  },
  {
    $mul: {
      "sales.salesByCategory.$.totalSales": 1.15
    }
  }
)

示例 7:负值和零

处理负乘数和零值。

db.stores.updateOne(
  { "_id": "438db151-04b8-4422-aa97-acf94bc69cfc" },
  {
    $mul: {
      "sales.totalSales": -1,
      "staff.totalStaff.fullTime": 0
    }
  }
)

这将:

  • 使 totalSales 负 (对逆转很有用)
  • fullTime 设置为 0

将 1.5 乘数应用于员工,将 1.25 应用于销售后,文档将按如下所示进行更新:

{
  "_id": "438db151-04b8-4422-aa97-acf94bc69cfc",
  "name": "Fourth Coffee | Turntable Boutique - Tromptown",
  "staff": {
    "totalStaff": {
      "fullTime": 12,
      "partTime": 10
    },
    "overtimeHours": 0
  },
  "sales": {
    "totalSales": 31078.75,
    "bonusPoints": 0,
    "salesByCategory": [
      {
        "categoryName": "Direct-Drive Turntables",
        "totalSales": 28592.45
      }
    ]
  }
}