我有两个表,一个叫做事件,另一个是会话。可以有多个具有相同session_name的事件,但每个事件只有一个session_name
class Session < ApplicationRecord
belongs_to :event, foreign_key: 'session_id'
end
class Event < ApplicationRecord
has_one :session
end
我不完全确定如何设置belongs_to和has_one。我曾尝试过查看教程和其他示例,但它们与我所拥有的有些不同。
在form_for事件中,如何在找到或创建新session_name的地方获取它并且session_id获取正确的id
在我的控制器中,我尝试使用此编辑表单,但这只显示事件的ID而非会话
def edit
@events = Event.find(params[:format])
@session = @events.session.id
end
我知道这是很多任何帮助或方向将被大量占用,我已经试图绕过这个我并不是最好的数据库和activerecord。我赞赏任何批评只是不是一个混蛋。
更新
我收到了要显示的编辑和新表单,但我如何将其保存/更新到数据库。这是我的表格。用户将填写的会话表中唯一的字段是session_name。当他们点击保存/更新时,我需要事件表来查找或创建sessions.id并将其插入events.session_id。
<%= form_for @session,html:{ class:'form-horizontal', style:'color:white;margin:auto;'}, url: signup_path do |s| %>
<%= s.fields_for :event do |e| %>
<label class="col-form-label">Event:</label>
<%= e.select(:eventname, [['Pink Ribbon Invite'],['2018 Missouri State Championship - KC']],{ :include_blank => false }, class: 'form-control')%>
<label class="col-form-label">First Name:</label>
<%= e.text_field(:firstname, class: 'form-control') %>
<label class="col-form-label">Last Name: </label>
<%= e.text_field(:lastname, class: 'form-control') %>
<label class="col-form-label">Phone Number: </label>
<%= e.telephone_field(:phone, class: 'form-control') %>
<label class="col-form-label">Email: </label>
<%= e.email_field(:email, class: 'form-control') %>
<label class="col-form-label">Street Address:</label>
<%= e.text_field(:streetaddress1, class: 'form-control') %>
<label class="col-form-label">Street Address 2: </label>
<%= e.text_field(:streetaddress2, class: 'form-control') %>
<label class="col-form-label">City:</label>
<%= e.text_field(:city, class: 'form-control') %>
<label class="col-form-label">State: </label>
<%= e.text_field(:state, class: 'form-control') %>
<label class="col-form-label">Zip:</label>
<%= e.text_field(:zip, class: 'form-control') %>
<label class="col-form-label">Gymnast</label>
<%= e.text_field(:gymnast, class: 'form-control') %>
<label class="col-form-label">Team Gym</label>
<%= e.text_field(:gym, class: 'form-control') %>
<label class="col-form-label">Session</label>
<%= s.text_field(:session_name, class: 'form-control') %>
<label class="col-form-label">Level</label>
<%= e.text_field(:level, class: 'form-control') %>
<label class="col-form-label">Product</label>
<%= e.select(:product, [["Digital - $80"],["Flash Drive - $100"],["Team Registration - $650"]], {} ,class: 'form-control') %>
<%= e.check_box(:terms, class:'') %>
<%= link_to 'Terms and Conditions', '#', data:{target: '#termsmodal', toggle: 'modal'}%>
<% end %>
<div>
<%= s.submit 'Sign Up', class:'btn btn-primary' %>
</div>
<% end %>
&#13;
def new
@session = Session.new()
@session.build_event
end
def create
@session = Session.find_or_create_by(session_name:
params[:session_name])
@event = @session #This is where i'm confused
@event.new(session_params)
if @session.save
flash[:success] = "You have successfully signed up"
redirect_to signup_path
else
render 'signup'
end
end
def edit
@events = Event.find(params[:format])
@session = Session.find(@events.session_id)
end
def update
puts params.inspect
@events = Event.find(params[:event][:id])
if @events.update_attributes(event_params)
redirect_to event_path
else
render 'edit'
end
end
答案 0 :(得分:0)
首先,你有错误的联想。包含reference
(在您的情况下为session_id
)的模型总是belongs_to
。所以你应该有
belongs_to :session
中的Event
和has_one :event
中的Session
。
要构建正确的表单,您应该使用嵌套属性。您可以查看示例Here。
一般来说,形式应该是这样的。
<%= form_for(@session) do |f| %>
...
<%= f.fields_for :event do |builder| %>
<%= builder.label :some_field, "Some field" %><br />
<%= builder.text_field :some_field %><br />
...
<% end %>
...
<% end %>
不要忘记在accepts_nested_attributes_for :event
Session