MongoDB聚合:$set

聚合$set阶段可以为文档添加新的字段。$set输出的文档包含输入文档中的所有现有字段和新添加的字段。$set$addFields的别名,从MongoDB4.2开始支持。$set$addFields等价于$project阶段,这两个阶段都等同于 $project 阶段,后者明确指定输入文档中的所有现有字段并添加新字段。

语法

{
   
    $set: {
   
    <newField>: <expression>, ... } }

指定要添加的每个字段的名称,并将其值设置为聚合表达式或空对象。

如果新字段的名称与现有字段的名称(包括 _id)相同,$set将用指定表达式的值覆盖该字段的现有值。

使用

  • 将新字段追加到现有文档中。可以在聚合操作中包含一个或多个$set阶段。
  • 接受对象嵌入,您可以将值设置为聚合表达式或空对象。例如,可接受嵌套对象:{$set:{ a:{ b: { }}}}
  • 要在嵌入文档(包括数组中的文档)中添加一个或多个字段,可以使用点符号。

例子

使用两个$set阶段

创建一个scores集合,并添加文档:

db.scores.insertMany([
   {
   
    _id: 1, student: "Maya", homework: [ 10, 5, 10 ], quiz: [ 10, 8 ], extraCredit: 0 },
   {
   
    _id: 2, student: "Ryan", homework: [ 5, 6, 5 ], quiz: [ 8, 8 ], extraCredit: 8 }
])

以下操作使用了两个$set阶段,在输出文档中加入三个新字段:

db.scores.aggregate( [
   {
   
   
     $set: {
   
   
        totalHomework: {
   
    $sum: "$homework" },
        totalQuiz: {
   
    $sum: "$quiz" }
     }
   },
   {
   
   
     $set: {
   
   
        totalScore: {
   
    $add: [ "$totalHomework", "$totalQuiz", "$extraCredit" ] } }
   }
] )

操作返回下面的文档:

{
   
   
  "_id" : 1,
  "student" : "Maya",
  "homework" : [ 10, 5, 10 ],
  "quiz" : [ 10, 8 ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

原子星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值