[英]Add information to DB from the controller on rails
我试图在用户成功提交表单后将用户ID添加到数据库的2列中。 这些命令在控制台中运行正常,但在控制器中不起作用。 之前我还没有直接从控制器向数据库添加信息,所以我认为我做错了什么。
这是创建方法
def create
@game = Game.friendly.find(params[:game_id])
@game_category = Game.friendly.find(@game.id).game_categories.new(game_category_params)
if current_user.mod_of_game? params[:game_id] && @game_category.save
Game.find(@game.id).game_categories.find(game_category.id).update(submitted_by: current_user.id)
Game.find(@game.id).game_categories.find(game_category.id).update(approved_by: current_user.id)
flash[:info] = "Game category added succesfully!"
redirect_to @game
else
render 'new'
end
end
这两行应该将用户ID添加到Submitted_by和roved_by列中,但没有添加。 我没有收到任何错误消息,他们只是不向这些列添加任何内容
Game.find(@game.id).game_categories.find(game_category.id).update(submitted_by: current_user.id)
Game.find(@game.id).game_categories.find(game_category.id).update(approved_by: current_user.id)
如果我将这些行替换为在控制台中可用的编码,以查看其是否为变量或不正确的内容,则仍然无法正常工作
Game.find(12).game_categories.find(55).update(submitted_by: 1)
Game.find(12).game_categories.find(55).update(approved_by: 1)
我正在构建一个用于学习Rails的应用程序,我想这只是我不知道的事情。
有人能启发我做错什么吗?
更新:
好的,现在给我一个错误-没有ID找不到GameCategory
所以@ game_category.id无法正常工作?
这是您错过@
的查询中的一个小错字。
Game.find(@game.id).game_categories.find(@game_category.id).update(submitted_by: current_user.id)
经过四处调整之后,原来是这条线
if current_user.mod_of_game? params[:game_id] && @game_category.save
当更改为此时
if @game_category.save && current_user.mod_of_game? @game
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.