我的数据库不会更新我的 active_quests。我要做的就是用另一个更新的哈希数组替换一个哈希数组。我认为这将是处理此问题的最简单方法。这是代码:
# construct the query
query = Player.where( :_id => player_id).fields( :xp, :lvl_prgrssns, :active_quests, :completed_quests )
# get the player
player = query.first
if !player.nil?
return_val = player.set( :active_quests => [{"quest_id" => "123"}, {"quest_id" => "456"}])
logger.debug "return_val = "+return_val.to_s # comes out as 180
end
我的理解是,如果一组的回报是积极的,那就意味着这组是成功的。在这种简化的情况下,它返回 180,但 active_quests 永远不会在播放器上更新。我可以进入 mongo 控制台并执行以下命令:
db.players.update({_id:ObjectId("50756b1896f4f5121a00000a")}, {$set:{active_quests:[{"quest_id":"1"}, {"quest_id":"2"}] }});
并且 active_quests 将按预期更新,但无论我在 Rails 中尝试什么,更新似乎都会通过,但没有任何更新。
以下是我尝试过的许多替代方案中的一些(所有都尝试过使用和不使用 .to_mongo 以及使用和不使用 player.save 之后):
Player.where( :_id => params[:player_id] ).update(:active_quests => active_quests_list.to_mongo)
player.update_attributes(:active_quests => active_quests_list.to_mongo)
player_update = player.as_json
player_update["active_quests"] = active_quests_list
player.update_attributes(player_update)
return_val = query.update( "$set" => {:active_quests => player.active_quests.to_mongo} )
return_val = query.update( {:_id => params[:player_id]}, {"$set" => {:active_quests => active_quests_list.to_mongo}})
我希望这里的人可能知道我做错了什么。