10

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

更新

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


原帖

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

将结构转换为 json 然后映射它是不行的,因为字段类型没有被保留。例如,让以下结构为Image model

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

到目前为止一切顺利,但是当我从客户端(即 javascript)接收信息时,视图字段是一个字符串。如果我将客户端提供的 json 输入转换为映射,则 views 字段仍然是一个字符串,并且该值的内部表示在数据库中发生更改。所以下次我从数据库中读取这个图像时,Views 字段被清零(因为它是来自数据库的字符串表示形式)。

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

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

到目前为止,我已经尝试了以下将结构转换为映射的功能,并且我使用反射包并且是使用它的菜鸟。不太了解这个包。

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

4

2 回答 2

26

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

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 变量中。将用户输入解析为另一个变量。在更新之前覆盖您需要保留的值。

于 2014-05-10T16:43:30.260 回答
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)
于 2021-02-10T04:46:47.013 回答