在文档 mongodb mgo 驱动程序中增加嵌套数组的特定值

这是我在 json 中的 mongo 集合:


"messages" : 

{

"_id" : ObjectId("5c26844696b72e4b6c9ceee7"),

"pointer" : ObjectId("5c26844696b72e4b6c9ceee6"),

"messages" : [ 

   {

       "uuid" : "f03f7977-0b4e-11e9-9f95-144fd7c03810",

       "content" : "Hello",

       "reportedTimes":0

   }, 

   {

       "uuid" : "78bb831d-0b57-11e9-a286-144fd7c03810",

       "content" : "Yes",

       "reportedTimes":0

   }

  ]

}

我想从“指针”和“uuid”更新“reportedTimes”值。我尝试了很多聚合,但没有像那个那样的结果:


pipe := []bson.M{bson.M{"$match": bson.M{"pointer": knownPointer}}, {"messages": bson.M{"$match": bson.M{"uuid": knownUUID}}}, {"$inc": bson.M{"messages.$.reportedTimes": 1}}}

那个返回我不能使用“$inc”


或者那个


pipe := []bson.M{{"$match": bson.M{"pointer": knownPointer}}, {"$unwind": "$messages"}, {"$project": bson.M{"uuid": "$messages.uuid", "reportedTimes": "$messages.reportedTimes"}}, {"$match": bson.M{"uuid": knownUuid}}} then inc.

我什至没有找到我所有的尝试查询......我完全被卡住了......我也尝试过 Update(selector, query) 但仍然找不到工作和有效的方法来做到这一点。一点帮助将不胜感激。谢谢大家。


大话西游666
浏览 100回答 1
1回答

幕布斯6054654

这是一个简单的Collection.Update()操作,不需要为此使用聚合:err := c.Update(bson.M{    "pointer":       knownPointer,    "messages.uuid": knownUUID,}, bson.M{    "$inc": bson.M{        "messages.$.reportedTimes": 1,    },})以下是设置参数以增加reportedTimes文档第一条消息的方法:knownPointer := bson.ObjectIdHex("5c26844696b72e4b6c9ceee6")knownUUID := "f03f7977-0b4e-11e9-9f95-144fd7c03810"
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go