更新某些用户字段

对我的 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


当年话下
浏览 151回答 1
1回答

RISEBY

我相信你应该能够做到这一点err := collection("users").Update(bson.M{"id" : user.Id},bson.M{"$set": &user})
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Go