3

使用 Rails 3.2。我的模型以这样的方式嵌套:

  • 评论 => 可评论(国家或商店)
  • 国家 => CountryDay => 商店 => 照片
  • 商店 => 照片

我有以下内容:

@reviews = @user.reviews.includes(:user, :reviewable)

通常我们可以通过这样的方式包含嵌套多态:

# this will return errors because :shop is not found in the model Shop (:reviewable is actually :shop)
@reviews = @user.reviews.includes(:user, :reviewable => [:shop])

# this will return errors because :photos is not directly associated to Country
@reviews = @user.reviews.includes(:user, :reviewable => :photos)

还有许多其他变体。如何解决它以使 ActiveRecord 包含基于其关联的正确模型?

4

1 回答 1

1

我想我刚才也遇到了同样的问题。我ActiveRecord::EagerLoadPolymorphicError在尝试加载关联时遇到了问题。我的解决方案是将自定义连接语句放在一起,我已将其放入范围中以便于使用。

未经测试,但这可能会让你继续:

class Review < ActiveRecord::Base
  scope :eagerly_loaded, -> {
    joins('
      INNER JOIN shops 
      ON (reviews.reviewable_type = "Shop" AND reviews.reviewable_id = shops.id)
      INNER JOIN countries 
      ON (reviews.reviewable_type = "Country" reviews.reviewable_id = countries.id)
    ')
  }
end

然后你使用@user.reviews.eagerly_loaded. 确保使用匹配的.group()-statement 只获取您需要的那些。

于 2013-10-09T19:59:01.330 回答