请告诉我谁在通过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"` ... }
- 1 回答
- 0 关注
- 71 浏览
添加回答
举报
0/150
提交
取消