适用对象:
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
}
]
}
}