Golang+mgo - 如何更新数据库文件?

Golang+mgo - how to update a db document?

我有一个 angularJS 前端使用 $resource 使用 HTTP 方法向我的 Go 服务器发送请求。我想在发送 PATCH 时更新现有的数据库条目。我需要向 GO 服务器提供多个数据字段。 angularJS 客户端应该如何以什么格式发送数据?从 mgo 文档中,我找到了下面要更新的代码。 Update 字段是否可以采用 Go 结构,该结构将从客户端收到的数据中解析并跳过空字段?

        change := mgo.Change{
            Update:    bson.M{"$inc": bson.M{"n": 1}},
            Upsert:    false,
            Remove:    false,
            ReturnNew: true,
        }
        info, err = col.Find(M{"_id": id}).Apply(change, &doc)
        fmt.Println(doc.N)

我的 angularjs 代码,我计划将数据作为查询发送。

            UpdateOneSchedule.update({bkresources:dbResources},
            function(data){
                //on success
            },
            function(httpResponse){
                //on error
                if(httpResponse.status === 409){
                }
            });

是的,这是可能的。一个简单的例子是:

var myStruct struct {
    Name string `json:"name" bson:"name,omitempty"`
    Age  int    `json:"age" bson:"age"`
}

您将数据解析到 myStruct 中并提供相同的对象进行更新。

change := mgo.Change{
    Update:    bson.M{"$inc": bson.M{"n": 1}, "$set": bson.M{"name": myStruct.Name}},
    Upsert:    false,
    Remove:    false,
    ReturnNew: true,
}
info, err = col.Find(M{"_id": id}).Apply(change, &doc)
fmt.Println(doc.N)

,omitempty 的工作方式与 JSON 的工作方式相同,意思是,如果它为空,则不会被解析,例如:

myStruct.Name = ""
myStruct.Age = 23
col.Insert(myStruct)

这将创建以下 BSON 文档:

{
    id: ObjectId("573da7dddd73171e42a84045"),
    age: 23
}