художников имеют много видов деятельности (в основном это кэш взаимодействий между пользователями):
class Activity < ActiveRecord::Base
belongs_to :receiver, :class_name => 'Artist', :foreign_key => :receiver_id #owns the stuff done "TO" him
belongs_to :link, :polymorphic => true
belongs_to :creator, :class_name => 'Artist', :foreign_key => :creator_id #person who initiated the activity
end
Например:
Activity.create(:receiver_id => author_id, :creator_id => artist_id, :link_id => id, :link_type => 'ArtRating')
Я хочу создать страницу потока действий для каждого исполнителя,состоящий из списка различных типов событий, ArtRatings (лайки, антипатии), Favoriting, Follow и т. д.
Контроллер выглядит так:объекты полиморфной ссылки:
SELECT "activities".* FROM "activities" WHERE (("activities"."receiver_id" = 6 OR "activities"."creator_id" = 6)) ORDER BY id DESC LIMIT 30
ArtRating Load (0.5ms) SELECT "art_ratings".* FROM "art_ratings" WHERE "art_ratings"."id" IN (137, 136, 133, 130, 126, 125, 114, 104, 103, 95, 85, 80, 73, 64)
SELECT "follows".* FROM "follows" WHERE "follows"."id" IN (14, 10)
SELECT "favorites".* FROM "favorites" WHERE "favorites"."id" IN (25, 16, 14)
Но когда я отображаю каждый ArtRating, мне также нужно ссылаться на заголовок поста, который принадлежит посту.По моему мнению, если я это сделаю:
activity.link.post
Это делает отдельный вызов БД для каждого сообщения art_rating.Есть ли способ загружать пост тоже?
ОБНОВЛЕНИЕ К ВОПРОСУ:
Если нет способа добиться быстрой загрузки постов с помощью «включает»Синтаксис, есть ли способ вручную выполнить запрос на загрузку самостоятельно и вставить его в объект @activities?
Я вижу в журнале БД:
SELECT "art_ratings".* FROM "art_ratings" WHERE "art_ratings"."id" IN (137, 136, 133, 130, 126, 125, 114, 104, 103, 95, 85, 80, 73, 64)
Есть ли способ, которым яполучить доступ к этому списку идентификаторов из объекта @activities?Если это так, я мог бы сделать 2 дополнительных запроса, 1 чтобы получить art_ratings.post_id (s) в этом списке, и еще один, чтобы ВЫБРАТЬ все сообщения в этом списке post_ids.Затем каким-то образом вставьте результаты 'post' обратно в @activities, чтобы они были доступны как activity.link.post, когда я выполняю итерацию по коллекции.Возможно ли это?