【发布时间】:2015-11-15 19:31:28
【问题描述】:
我正在尝试传递两个隐藏字段和一个答案来创建一个新的答案对象。尽管我可以看到哈希中的所有参数,但似乎隐藏的参数没有正确包含在答案中。我确定这只是我做错的一件简单的事情,但无法弄清楚它在哪里。欣赏时间!
参数哈希:
参数:
{"utf8"=>"✓",
"authenticity_token"=>"VaZC2MCN0rWJnVPIqSTbPF9HvFNBfm5b5nA3H8YenuVte9SMi9Iy+G4fxz9bWhkDNwGVz9jMBVTxT/SuXFCh+A==",
"user_id"=>"2",
"question_id"=>"1",
"answer"=>{"answer"=>"a"},
"commit"=>"Create Answer"}
错误: SQLite3::ConstraintException: NOT NULL 约束失败:answers.user_id: INSERT INTO "answers" ("created_at", "updated_at") VALUES (?, ?)
_mc_answer.html.erb(部分我用作选择题的表格。)
这应该将 question_id 和 user_id 连同用户的答案一起传递到 static_pages 控制器并创建一个新的 Answer 对象。
<h4>MC Answer:</h4>
<p>User ID: <%= @user.id %></p>
<p>Question ID: <%= question_id %></p>
<%= form_for(@new_answer, url: static_pages_path(@new_answer)) do |a| %>
<%= hidden_field_tag :user_id, @user.id %>
<%= hidden_field_tag :question_id, question_id %>
<%= a.text_field :answer %>
<%= a.submit %>
<% end %>
static_pages_controller.rb
class StaticPagesController < ApplicationController
def index
@user = current_user
if user_signed_in?
if @user.manager_id != nil
@manager = @user.manager_id
end
@my_team = User.where("manager_id = ? AND id != ?", @manager, @user.id)
@questions = Question.active_question.where.not(id: @user.answers)
end
@new_answer = Answer.new
end
def new
@new_answer = Answer.new
end
def create
@user = current user ## Tried adding this to the create method per suggestion below but still getting the same issue.
@new_answer = Answer.new(answer_params)
if @new_answer.save!
flash.now[success]
else
end
end
private
## Edited params from .permit(:answer => [:user_id, :question_id, :answer]) but still getting similar error.
def answer_params
params.require(:answer).permit(:user_id, :question_id, :answer)
end
end
answer.rb 模型
class Answer < ActiveRecord::Base
belongs_to :question
belongs_to :user
scope :user_answered, lambda {|q| where("question_id == (?)", q) }
def next
Answer.where("id > ?", id).limit(1).first
end
def prev
Answer.where("id < ?", id).limit(1).first
end
end
DB Schema for answer model if that's of any use:
ActiveRecord::Schema.define(version: 20151112025039) do
create_table "answers", force: :cascade do |t|
t.integer "user_id", null: false
t.integer "question_id", null: false
t.integer "points_earned"
t.text "comment"
t.text "answer", null: false
t.datetime "created_at", null: false
t.datetime "updated_at", null: false
end
add_index "users", ["confirmation_token"], name: "index_users_on_confirmation_token", unique: true
add_index "users", ["email"], name: "index_users_on_email", unique: true
add_index "users", ["reset_password_token"], name: "index_users_on_reset_password_token", unique: true
add_index "users", ["unlock_token"], name: "index_users_on_unlock_token", unique: true
end
【问题讨论】:
-
在有问题的请求期间服务器日志的完整输出可能会有所帮助。
标签: ruby-on-rails forms ruby-on-rails-4 parameters