我们如何通过关联在has_many中设置其他参数?
感谢。 Neelesh
答案 0 :(得分:12)
此博客文章提供了完美的解决方案:http://www.tweetegy.com/2011/02/setting-join-table-attribute-has_many-through-association-in-rails-activerecord/
该解决方案是:手动创建“:through model”,而不是在附加到其所有者的数组时通过自动方式创建。
使用该博客文章中的示例。您的模型在哪里:
class Product < ActiveRecord::Base
has_many :collaborators
has_many :users, :through => :collaborators
end
class User < ActiveRecord::Base
has_many :collaborators
has_many :products, :through => :collaborators
end
class Collaborator < ActiveRecord::Base
belongs_to :product
belongs_to :user
end
以前你可能已经离开:product.collaborators << current_user
。
但是,要设置附加参数(在此示例中为is_admin
),而不是自动添加到数组的方式,您可以手动执行以下操作:
product.save && product.collaborators.create(:user => current_user, :is_admin => true)
此方法允许您在保存时设置其他参数。 NB。如果模型尚未保存,则product.save
是必需的,否则可以省略。
答案 1 :(得分:1)
has_many :tags, :through => :post_tags, :conditions => ['tag.owner_id = ?' @owner.id]
答案 2 :(得分:1)
我遇到了类似的情况,我希望有一个加入3个模型的连接表。但是我希望从第二个模型中获得第三个模型ID。
class Ingredient < ActiveRecord::Base
end
class Person < ActiveRecord::Base
has_many :food
has_many :ingredients_food_person
has_many :ingredients, through: :ingredients_food_person
end
class Food
belongs_to :person
has_many :ingredient_food_person
has_many :ingredients, through: :ingredients_food_person
before_save do
ingredients_food_person.each { |ifp| ifp.person_id = person_id }
end
end
class IngredientFoodPerson < ActiveRecord::Base
belongs_to :ingredient
belongs_to :food
belongs_to :person
end
令人惊讶的是,你可以这样做:
food = Food.new ingredients: [Ingredient.new, Ingredient.new]
food.ingredients_food_person.size # => 2
food.save
起初我认为在保存之前,在分配#ingredients后我无法访问#ingredients_food_person。但它会自动生成模型。
答案 3 :(得分:0)
在这里遇到同样的问题。找不到任何教程如何让它在Rails 3中即时工作。 但是你仍然可以通过连接模型获得你想要的东西。
p = Post.new(:title => 'Post', :body => 'Lorem ipsum ...')
t = Tag.new(:title => 'Tag')
p.tags << t
p.save # saves post, tag and also add record to posttags table, but additional attribute is NULL now
j = PostTag.find_by_post_id_and_tag_id(p,t)
j.user_id = params[:user_id]
j.save # this finally saves additional attribute
非常难看,但这对我有用。