dongpouda6700
dongpouda6700
采纳率100%
2019-07-08 03:21

如何更新多个MongoDB字段

已采纳

我对Go官方MongoDB感到非常沮丧。 确实没有文档。 我正在尝试更新集合中的多个字段。 通常,所有引用都是最简单且更新一个字段:

    update := bson.D{bson.E{"$set", bson.E{"releaseimage", r.ReleaseImage}}}

那个有效。 我尝试了各种方法来扩展它以设置两个字段并获取错误:

    update := bson.D{
        {"$set",
            bson.E{"releaseimage", r.ReleaseImage},
            //bson.E{"releasepath", r.ReleasePath},
        },
        // {"$set",
        //  bson.E{
        //      "releasepath", r.ReleasePath}},
    }

第一次删除了第一组中的注释。 第二次尝试的语法无效,请删除第二组注释,因为是无效的语法。 我很茫然。 为了继续前进,我正在进行两次更新,一次又一次。 效率低下。

谢谢。

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享
  • 邀请回答

2条回答

  • donglei1699 donglei1699 2年前

    For multiple fields, you have to create an array of bson element(bson.E). then append/assign as many fields you want in array item.

    var update []bson.E
    if r.ReleaseImage != "" {
        update = append(update, bson.E{"releaseimage", r.ReleaseImage})
    }
    if r.Releasepath != "" {
        update = append(update, bson.E{"releasepath", r.Releasepath})
    }
    // now update db
    result, err := coll.UpdateOne(
            context.Background(),
            bson.D{
                {"id", r.ID},
            },
            bson.D{
                {"$set", update},
                {"$currentDate", bson.D{
                    {"updated", true},
                }},
            },
        )
    

    Hope this helps

    点赞 评论 复制链接分享
  • doushi6864 doushi6864 2年前

    Simply do like this:

    uQuery := make(bson.M)
    if len(r.ReleaseImage)>0{
      uQuery["releaseimage"]=r.ReleaseImage
    }
    if len(r.Releasepath)>0{
      uQuery["releasepath"]=r.Releasepath
    }
    updateQ := make(bson.M)
    updateQ["$set"] = uQuery
    

    Now simply pass 'updateQ' to mongodb update Wrapper function along with findQuery.

    点赞 评论 复制链接分享

为你推荐