首页 > 解决方案 > 无法在 Rails 5 应用程序中添加行以加入表

问题描述

我有三个表 - result、feedback_qs 和 feedback_qs_results(连接表)。给定现有结果和 feedback_qs,我想用 result_id、feedback_q_id 和后续答案 (text_area) 填充连接表。

我相信关系是正确的......

# result.rb
has_many :feedback_q_results
has_many :feedback_qs, :through => :feedback_q_results

# feedback_q.rb
has_many :feedback_q_results
has_many :results, :through => :feedback_q_results

# feedback_q_result.rb
belongs_to :result
belongs_to :feedback_q

我可以通过下面的 config/routes.rb 访问 result_id(result/result.id/feedback)...

resources :results do
  member do
    get 'feedback'
    post 'feedback_create'
  end
end

这个表单填充连接表会是什么样子?类似的东西(我意识到这是不正确的)......?如何通过 post_controller 获取数据以填充连接表?还是应该通过另一个控制器?

<%= form_for :result, url: feedback_create_result_path(result), method: :post do |form| %>
  <% for q in FeedbackQ.all %>
  <div class="col field">
    <p>
      <%= form.label q.question_text %>
    </p>
    <%= text_area_tag id: q.id %>
  </div>
  <% end %> 

  <div class="actions">
    <%= form.submit "Submit", class: "btn btn-primary" %>
  </div>
<% end %>

我的 feedback_create 方法会是什么样子?虽然我已经看到几个关于 Rails 的多对多关系和填充连接表的问题,但这些用例似乎都不适合我的需要。提前致谢。

更新 - 我的用例是这样的:用户参加考试(称为结果),然后他们通过回答反馈问题来审查监考人员。我想在连接表中记录反馈

标签: ruby-on-railsrubyhas-many-throughjointable

解决方案


如果您的 has_many 关联工作正常,那么在 rails 控制台中您应该能够执行以下操作:

> result.feedback_qs
=> []

> feedback_q.results
=> []

Whereresultfeedback_qare 分别是ResultFeedbackQ对象。

要将 feedback_q 与结果相关联,只需:

> result.feedback_qs << feedback_q

feedback_q_result这应该在表中创建一条记录。现在,当你这样做时

> result.feedback_qs

它应该返回feedback_q您刚刚添加的记录。


推荐阅读