У меня есть продукт, и у продукта может быть много изображений. Это через таблицу ассоциаций. Тем не менее, я хотел бы, чтобы у продукта было одно основное изображение.
Я знаю, что это очень легко сделать с методом в модели, но я хочу, чтобы это была ассоциация, чтобы я мог предварительно загрузить его в запросе с помощью include
.
Модели:
class Product < ActiveRecord::Base
has_many :image_associations, :as => :imageable
has_many :images, :through => :image_associations
end
class ImageAssociation < ActiveRecord::Base
belongs_to :image
belongs_to :imageable, :polymorphic => true
end
class Image < ActiveRecord::Base
has_many :image_associations
end
В таблице ImageAssociation имеется булевский столбец с названием "функция", который связывает изображение как "основное" изображение.
Один из способов, которым я думал об этом, - добавить столбец main_image_id
в таблицу продуктов, а затем добавить в модель Image
:
belongs_to :image, :class => "Image", :foreign_key => "main_image_id"
Однако это не позволяет отказаться от других has_many изображений, если основное изображение равно nil - что я хотел бы, чтобы ассоциация загружалась.
Вот почему я надеялся на что-то в модели изображений, например:
has_one :image, :through => :images, :conditions => 'feature = true', :order => 'created_at DESC'
Но это дает мне ошибку ассоциации.
Можно ли каким-либо образом изменить это has_one или мне действительно нужно запустить задачу rake, чтобы вставить изображение в каждое поле main_image_id, а затем добавить подтверждение для будущих продуктов, чтобы убедиться, что основное изображение было добавлено?
EDIT:
Должен ли я использовать ассоциацию has_and_belongs_to_many
?