繁体   English   中英

从导轨上的控制器向DB添加信息

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM