我有三个模型:
class Product < ActiveRecord::Base
has_many :product_recommendations, :dependent => :destroy
has_many :recommendations, :through => :product_recommendations
end
class Recommendation < ActiveRecord::Base
has_many :product_recommendations, :dependent => :destroy
has_many :products, :through => :product_recommendations
end
class ProductRecommendation < ActiveRecord::Base
belongs_to :recommendation
belongs_to :product
end
我还有一个创建新推荐的方法:
def self.get_recommendation(product, rating_set)
r = Recommendation.create
r.title = @title
r.description = @description
r.cover_img = @image_url
r.curr_price = @curr_item_price
r.save!
end
当我调用该方法时,我传入了产品对象和rating_set属性。
如何创建与1)产品对象的product_recommendation关联?2)新创建的推荐对象。3)一个附加属性(rating_set),它属于producrecommendation连接表。
我尝试了以下操作,但没有成功:
product.create_product_recommendations( {:rating_set => rating_set}, {:recommendation => r} )
product.recommendations.create( :rating_set => rating_set, :recommendation => r )
我通过在连接表上创建这样的记录来解决这个问题:
pr = ProductRecommendation.new(:rating_set => rating_set.id, :recommendation_id => r.id, :product_id => product.id)
pr.save!
你很接近…
product.product_recommendations.create( {:rating_set => rating_set}, {:recommendation => r} )
在您提到的方法中- 'create'方法将创建一个新项目并将其放入DB中。那可能不是你想要的。相反,使用'new'并为新推荐设置参数,如下所示:
r = Recommendation.new(title: @title, description: @description, etc.).
r.save
如果您在控制器中执行此操作,则可能不需要将其拆分为单独的方法。只需在控制器中调用new和save (create action)——这将允许你处理错误、重定向等。