我已经安装了以下Rails 5模型:
JobTitle
has_many :job_title_skills
has_many :skills, through: :job_title_skills
Skills
has_many :job_title_skills
has_many :job_titles, through: :job_title_skills
JobTitleSkills
belongs_to :job_title
belongs_to :skill
validates :job_title_id, uniqueness: { scope: :skill_id }我想要做的是:
skill1 = Skill.find_or_create_by(title: 'YYY')
job_titles = JobTitle.all
job_titles.each_with_index do |job_title, index|
case job_title.title
when "XXXXX"
job_title.skills << skill1
end
end上面的代码在我第一次运行它时运行得很好,但是一旦在数据库中创建了记录,上面的错误信息就会出现:
ActiveRecord::RecordInvalid: Validation failed: Job title has already been taken我如何更新上面的内容,使<<只在记录不存在的情况下才创建,而不是创建?
发布于 2017-08-07 02:20:13
job_title.job_title_skills.find_or_create_by(skill: skill)
https://stackoverflow.com/questions/45534462
复制相似问题