为了账号安全,请及时绑定邮箱和手机立即绑定

使用 mgo 时的更新插入问题

使用 mgo 时的更新插入问题

Go
蛊毒传说 2022-10-04 16:12:15
请告诉我谁在通过mgo与Mongo合作时遇到了这个问题。我需要更新文档,如果没有文档,请插入一个新文档,我使用Upsert():entry := models.Example{    ID:           bson.NewObjectId(),    UserID:       userID,    SessionID:    sessionID,    Created:      created,  }query := bson.M{  "$set": entry,}_, err = mongo.C(mongodb.ExampleCollection).Upsert(bson.M{  "user_id":      userID,  "session_id":   sessionID,}, query)因此,它会插入文档,并在更新时中断(&mgo.LastError {Err: “在路径'_id'上执行更新将修改不可变字段'_id'”,...}),如果删除以前生成的ID,则它无法在没有ID的情况下插入它。我也读到$setOnInsert,但显然它在ID上不是这样工作的:query := bson.M{  "$setOnInsert": bson.M{    "_id": bson.NewObjectId(),  },  "$set": entry,}
查看完整描述

1 回答

?
qq_笑_17

TA贡献1818条经验 获得超7个赞

在我的特定情况下,在bson标签中添加“omitempty”对我有所帮助。没有它,我无法在没有ID的情况下写入其中一个,它不是自动生成的。

models.Example{
    ID    bson.ObjectId    `bson:"_id,omitempty"`
    ...
}


查看完整回答
反对 回复 2022-10-04
  • 1 回答
  • 0 关注
  • 71 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信