是否可以在同一个字段上分配多个has_many“:as”多态关系?

时间:2012-09-12 12:57:02

标签: ruby-on-rails activerecord associations has-many-polymorphs

我的数据库设置是这样的(“类型”总是用户,虽然我通过STI有不同类型的用户):

class User 
  # fields
  # :id
  # :sender_id, :sender_type
  # :recipient_id, :recipient_type
end

明信片模型:

class Postcard < ActiveRecord::Base
  belongs_to :owner, :class_name => User
  belongs_to :recipient, :class_name => User
end

我想设置这样的用户模型:

class User < ActiveRecord::Base
  has_many :postcards, :as => [:sender or :recipient] # this is not working
end

所以我可以说:

user.postcards

有可能吗?

PS:我也试过这条路:

  has_many :postcards, :finder_sql => Proc.new { "SELECT * FROM postcards WHERE postcards.owner_id=#{id} OR postcards.recipient_id=#{id}" }

但发现自己坚持使用范围:finder_sql重新创建一个全新的SQL:

  User.postcards.by_status('new').size

1 个答案:

答案 0 :(得分:0)

正如joelparkerhenderson所提到的,我需要以不同的方式思考我的关联策略。

正如我想要的那样:

user.postcards

我的回答只是在明信片模型中使用范围:

scope :of_user, lambda { |user| where("recipient_id = ? OR owner_id = ?", user.id, user.id) }

所以我可以调用:

Postcard.of_user user

我甚至可以将它包装在用户模型中:

def postcards
   Postcard.of_user self
end