Tag: 拥有并且属于多种

将记录添加到has_and_belongs_to_many关系中

我有两个模型,用户和促销活动。 这个想法是促销可以有很多用户,用户可以有很多促销。 class User < ActiveRecord::Base has_and_belongs_to_many :promotions end class Promotion < ActiveRecord::Base has_and_belongs_to_many :users end 我还有一个promotion_users表/模型,没有自己的id。 它引用了user_id和promotions_id class PromotionsUsers < ActiveRecord::Base end 那么,如何将用户添加到促销中? 我尝试过这样的事情: user = User.find(params[:id]) promotion = Promotion.find(params[:promo_id]) promo = user.promotions.new(promo) 这会导致以下错误: NoMethodError: undefined method `stringify_keys!’ for # 如果我改为尝试这一行:promo = user.promotions.new(promo.id) 我收到此错误: TypeError: can’t dup Fixnum 我确信我的问题有一个非常简单的解决方案,而我只是没有以正确的方式寻找解决方案。