我有模型。
但是,单独使用这段代码基本上没有什么作用。与更新机构相结合,这段代码可以正常运行。我做错了什么?
在当前实现中,它会发出错误提示:
class Agency < ActiveRecord::Base
has_many :specializations
has_many :cruise_lines, through: :specializations
end
class CruiseLine < ActiveRecord::Base
has_many :specializations
has_many :agencies, through: :specializations
end
class Specialization < ActiveRecord::Base
belongs_to :agency, inverse_of: :specializations
belongs_to :cruise_line, inverse_of: :specializations
end
我希望更新Specialization
集合(即删除一些旧关系并在需要时添加一些新关系)。我的方法应该更新关系,看起来像这样(在某个独立的服务内):
def self.update_agency_specializations(agency, params)
attributes = params.require(:agency).permit( { cruise_line_ids: [] } )
attributes[:cruise_line_ids].select{ |x| x.to_i > 0 }.each do |cruise_line_id|
agency.specializations.build(cruise_line_id: cruise_line_id)
end
return false if agency.errors.present?
true
end
但是,单独使用这段代码基本上没有什么作用。与更新机构相结合,这段代码可以正常运行。我做错了什么?
在当前实现中,它会发出错误提示:
ERROR: duplicate key value violates unique constraint "index_specializations_on_agency_id_and_cruise_line_id" DETAIL: Key (agency_id, cruise_line_id)=(1, 3) already exists.
这意味着它试图保存新关系,而尚未删除旧关系,因此违反了相同条目的索引。