есть ли способ загружать ассоциации полиморфных ассоциаций?

у художников много действий (в основном это кэш взаимодействия между пользователями):

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 (нравится, не нравится), добавления в избранное, подписки и т. д.

Контроллер выглядит следующим образом:

class ActivityStreamController < ApplicationController
  def index
    @activities = @artist.activities.includes([:link,:creator,:receiver]).order("id DESC").limit(30)
  end
end

Вызов db корректно загружает объекты полиморфных ссылок :

  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 при итерации по коллекции. Возможно?

8
задан aromero 1 November 2013 в 01:24
поделиться