mongodb 不管存在不存在該值都會回傳1?
某草草
某草草 2017-05-02 09:21:43
0
1
638

update({"tag":"9_14712612489","funding_id":9,"inventory_num":{"$gt":0}},{"$inc":{"inventory_num":-1}})

就是查找大於0的然後-1
但是這個資料不存在 也會回傳true 是我程式接住了異常還是本來就是這樣?

某草草
某草草

全部回覆(1)
过去多啦不再A梦

這裡主要是true和false的理解不同。 true代表更新的操作成功了,但不一定更新了任何記錄。 false代表更新的操作失敗了,可能是各種系統錯誤和異常,例如連不上mongod。

> db.user.update({"username": "test"}, {"source": "ios"})
WriteResult({ "nMatched" : 1, "nUpserted" : 0, "nModified" : 1 })
> db.user.update({"username": "xxxx"}, {"source": "ios"})
WriteResult({ "nMatched" : 0, "nUpserted" : 0, "nModified" : 0 })

像上面的例子,兩個回傳的都是true,因為他們的操作都成功了,不管有沒有更新

熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板