Ruby 活动记录关联未保存在数据库中

Ruby 活动记录关联未保存在数据库中,ruby,forms,ruby-on-rails-4,activerecord,associations,Ruby,Forms,Ruby On Rails 4,Activerecord,Associations,我有两种型号: class Tool < ActiveRecord::Base belongs_to :user end class User < ActiveRecord::Base has_many :tools, dependent: :destroy end 如何使用登录用户的id更新用户的id?我是否必须在表单中包含隐藏字段或类似的内容 我还必须在控制器的强参数中允许user_id变量吗?我已经试过了,但没有解决问题 这是如何工作的?目前您正在自行构建一个工

我有两种型号:

class Tool < ActiveRecord::Base
    belongs_to :user
end

class User < ActiveRecord::Base
  has_many :tools, dependent: :destroy
end
如何使用登录用户的id更新用户的id?我是否必须在表单中包含隐藏字段或类似的内容

我还必须在控制器的强参数中允许user_id变量吗?我已经试过了,但没有解决问题


这是如何工作的?

目前您正在自行构建一个工具。要将其与用户模型关联,您需要按以下方式创建工具模型:

@user.tools.build

它将创建一个新的ActiveRecord工具模型,该模型具有所属模型的适当用户id。但要获得父项,您需要从参数获取其id。在你的行动中,可以这样做:

@user=user.findparams[:user\u id]

注意:为使之成为可能,您的路线应相应嵌套,请阅读以下内容:

因此,总而言之,您的新操作应该如下所示:

def new
  @user = User.find(params[:user_id])
  @tool = @user.tools.build
end
在你的路线上

resources :users do
  resources :tools
end

您没有包括最重要的部分,即您实际处理表单提交数据的控制器中的操作。@meagar我已使用控制器代码更新了我的问题。嗯,也许我需要在控制器中添加一些逻辑。类似于:@user.tools.buildparams[:user][:tool]rails中对这种事情的约定是什么?如果我不想嵌套路由怎么办?这会改变我应该做的吗?我在任何地方都找不到任何信息。@coderwanabe2,基本上你只需要知道用户或其id。在嵌套路由中,可以很容易地从参数中获取其id。但您也可以手动将其输入表单中。那么在新操作@user=user.findparams[:user\u id]中就不需要这行代码了。但您需要为用户id创建一个字段,并输入用户的id。或者,您可以使用“选择字段”从现有用户列表中进行选择。我是否可以不创建字段进行选择?这似乎不是一个优雅的解决方案。。。我相信一定有一种方式,这看起来像是一个常见的用例。@coderwanabe2思考一下您的工具模型如何知道它应该属于哪些用户?可以有1个、100个或1000 000个用户。他们中的哪一个应该有这个工具?你能给我举个例子,用代码说明你的意思吗?我想我可能误解了你的意思。我不想有嵌套的资源,但我不知道如何将工具附加到用户创建的没有嵌套或没有表单字段的文件。
irb(main):002:0> Tool.last
  Tool Load (0.0ms)  SELECT  "tools".* FROM "tools"  ORDER BY "tools"."id" DESC LIMIT 1
=> #<Tool id: 6, name: "wrench2", description: "another wrench", created_at: "2015-04-09 21:38:47", updated_at: "2015-04
-09 21:38:47", tool_image_file_name: "wrench.jpg", tool_image_content_type: "image/jpeg", tool_image_file_size: 3424, to
ol_image_updated_at: "2015-04-09 21:38:43", user_id: nil>
irb(main):003:0>
class ToolsController < ApplicationController
  before_action :authenticate_user!, only: [:new, :destroy, :edit, :update], notice: 'you must sign in first!'
  before_action :set_tool, only: [:show, :edit, :update, :destroy]

  # GET /tools
  # GET /tools.json
  def index
    @tools = Tool.all
  end

  # GET /tools/1
  # GET /tools/1.json
  def show
  end

  # GET /tools/new
  def new
    @tool = Tool.new
  end

  # GET /tools/1/edit
  def edit
  end

  # POST /tools
  # POST /tools.json
  def create
    @tool = Tool.new(tool_params)

    respond_to do |format|
      if @tool.save
        format.html { redirect_to @tool, notice: 'Tool was successfully created.' }
        format.json { render :show, status: :created, location: @tool }
      else
        format.html { render :new }
        format.json { render json: @tool.errors, status: :unprocessable_entity }
      end
    end
  end

  # PATCH/PUT /tools/1
  # PATCH/PUT /tools/1.json
  def update
    respond_to do |format|
      if @tool.update(tool_params)
        format.html { redirect_to @tool, notice: 'Tool was successfully updated.' }
        format.json { render :show, status: :ok, location: @tool }
      else
        format.html { render :edit }
        format.json { render json: @tool.errors, status: :unprocessable_entity }
      end
    end
  end

  # DELETE /tools/1
  # DELETE /tools/1.json
  def destroy
    @tool.destroy
    respond_to do |format|
      format.html { redirect_to tools_url, notice: 'Tool was successfully destroyed.' }
      format.json { head :no_content }
    end
  end

  private
    # Use callbacks to share common setup or constraints between actions.
    def set_tool
      @tool = Tool.find(params[:id])
    end

    # Never trust parameters from the scary internet, only allow the white list through.
    def tool_params
      params.require(:tool).permit(:name, :description, :tool_image, :user_id)
    end

end
def new
  @user = User.find(params[:user_id])
  @tool = @user.tools.build
end
resources :users do
  resources :tools
end