如何解决使用collection_select通过has_many和belongs_to关联保存预订中两个班级的ID时,保存时抛出错误“必须存在”
我正在构建一个用于学习 Rails 的简单预订应用程序。我为人员、汽车和预订搭建了脚手架。
现在,当我尝试创建预订时,我得到了
2 个错误导致无法保存此预订:
- 人必须存在
- 汽车必须存在
代码
car.rb
class Car < ApplicationRecord
has_many :bookings
def brand_with_licence_plate
"#{brand} #{licence_plate}"
end
end
person.rb
class Person < ApplicationRecord
has_many :bookings
def complete_name
"#{first_name} #{last_name}"
end
end
bookings.rb
class Booking < ApplicationRecord
belongs_to :Person
belongs_to :Car
end
我像这样添加了 ID 列:
class AddItemsToBookings < ActiveRecord::Migration[6.1]
def self.up
add_column :bookings,:car_id,:integer
add_column :bookings,:person_id,:integer
end
end
<div class="field">
<%= form.label :Person %>
<%= form.collection_select(:person_id,Person.all,:id,:complete_name) %>
</div>
<div class="field">
<%= form.label :Car %>
<%= form.select :car_id,options_from_collection_for_select(Car.all,'id','brand_with_licence_plate') %>
</div>
并添加到 bookings_controller.rb
def booking_params
params.require(:booking).permit(:start,:end,:car_id)
end
我查看了 here 并尝试按照一个答案中的说明更改为 <%= form.select :car_id,'brand_with_licence_plate') %>
,但给了我同样的错误。
当我查看 documentation 时,一切似乎也很好。
似乎在这里遗漏了一些基本的东西。感谢您提供如何解决此问题的任何想法。
更新:
我删除了整数 id 列并运行了新的迁移
class AddReferencesToBookingForPersonAndCar < ActiveRecord::Migration[6.1]
def change
add_reference :bookings,:people,foreign_key: true
add_reference :bookings,:cars,foreign_key: true
end
end
并调整了参数的权限。
解决方法
你的代码在我看来不太好。我会改变它:
class Booking < ApplicationRecord
belongs_to :person
belongs_to :car
end
主要是person和car都是小写的。另外,我注意到在你的迁移中你创造了复数形式的汽车。应该是:
class AddReferencesToBookingForPersonAndCar < ActiveRecord::Migration[6.1]
def change
add_reference :bookings,:person,foreign_key: true
add_reference :bookings,:car,foreign_key: true
end
end
belongs_to :car 需要一个 car_id,看起来迁移正在创建一个 cars_id。
如果您发布完整的控制器代码,提供更多帮助会更容易。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。