对我的 API 的请求包含 ID(必需)和可选的其他字段,例如姓名、电子邮件和用户名。
{
"id" : "12345",
"name" : "Bob",
"email" : "test@example.com"
}
将请求绑定到结构后,user如果我的数据库中没有具有该 ID 的用户,我会使用以下方法将它们添加到其中:
user.App_id = appId
user.Created_at = (*tools.Timestamp)(&now)
user.Updated_at = (*tools.Timestamp)(&now)
_ = C.Database.C("users").Insert(&user);
但如果有用户,我只想更新请求对象包含的字段,但我不确定如何编写查询。
我的user结构使用指针,以便我可以检查nil值
type user struct {
Id *string `bson:"id" json:"id"`
Name *string `bson:"name" json:"name"`
...
}
我在应用程序的其他地方使用的更新查询如下所示:
err := collection("users").Update(bson.M{"id" : "user.Id"},bson.M{"$set": bson.M{"???":"???"}})
但我不确定在这些情况下如何构建查询的后半部分。
注意:我没有使用 MongoDB 的 _id
RISEBY
相关分类