使用mgo进行部分更新

时间:2014-05-10 15:55:07

标签: go mgo

我有以下问题。我需要将structure转换为map[string]interface{}才能在数据库中执行更新(使用mgo作为mongodb的驱动程序)。

更新

对于部分更新mongoDB中的文档,(最佳)解决方案是转换为地图并删除不需要的字段。要从struct转换为map,请参阅my other post


原帖

我从客户端javascript接收数据并在我的struct模型中写入。但我不想更改/更新某些字段,因此我需要将我的结构转换为map[string]interface{}以删除不需要的字段。

将结构转换为json,然后将其映射不正确,因为不保留字段类型。例如,让以下结构为Image model

type Image struct {
    Name string `json:name`
    Views int `json:views,string`
    Owner string `json:owner`
}

到目前为止一直很好,但是当我从客户端(即javascript)收到信息时,views字段是一个字符串。如果我将从客户端给出的json输入转换为map,那么views字段仍然是一个字符串,并且该值的内部表示在数据库中更改。因此,下次我从数据库中读取此图像时,“视图”字段将归零(因为它是来自数据库的字符串表示)。

因此,我在结构中编写了来自客户端的json输入(用于View变量的正确转换)。但是所有者的价值不应该改变(一种形式的数据库)。所以我需要再次将结构转换为map [string] interface {}并在数据库中进行更新之前处理该映射。

使用json包它不是一个选项,因为Views字段中的字符串标记将从int转换为string(转换为map时)。

到目前为止,我已尝试使用以下函数将结构转换为地图,并使用反射包并使用它作为菜鸟。不太了解这个包裹。

如果你想出一些想法,我将不胜感激。 感谢。

2 个答案:

答案 0 :(得分:23)

解决方案可以是:
1. client json - > struct - > xml - > map - > database
2.使用$set运算符更新partital:

collection.Update(bson.M{"_id": id}, bson.M{"$set": bson.M{"name": "new Name"}}

了解详情:http://docs.mongodb.org/manual/reference/operator/update/set/
3.加载要更新的文档并将其存储在tmp变量中。将用户输入解析为另一个变量。在更新之前覆盖您需要保留的值。

答案 1 :(得分:0)

如果您使用 go.mongodb.org/mongo-driver,则必须使用 UpdateOne 方法来更新特定字段。 这是代码

    database := db.Conn.Database("myDatabase")
    coll := database.Collection("myCollection")
    
    filter := bson.M{"_id": bson.M{"$eq": objectHexID}}
    update := bson.M{"$set": bson.M{"useremail": "abc@email.com"}}

    updated, err := coll.UpdateOne(ctx, filter, update)