Ruby on rails 具有多个条目的rails 3 habtm过滤

Ruby on rails 具有多个条目的rails 3 habtm过滤,ruby-on-rails,ruby,ruby-on-rails-3,has-and-belongs-to-many,Ruby On Rails,Ruby,Ruby On Rails 3,Has And Belongs To Many,我有产品型号和产品类别型号。在这两者之间有一个habtm 我有像“男人”和“牛仔裤”这样的分类,我想过滤这些。对男士进行过滤没有问题,但我需要过滤多个参数(男士和牛仔裤)。我尝试了一些变化,但我被困在这个 这就是我到目前为止所拥有的 Product.joins(:product_categories).where(['product_categories.id = 5 and product_categories.id = 6']) 谢谢你的时间 这样写,并传递一组要筛选的ID,怎么样 Pro

我有产品型号和产品类别型号。在这两者之间有一个habtm

我有像“男人”和“牛仔裤”这样的分类,我想过滤这些。对男士进行过滤没有问题,但我需要过滤多个参数(男士和牛仔裤)。我尝试了一些变化,但我被困在这个

这就是我到目前为止所拥有的

Product.joins(:product_categories).where(['product_categories.id = 5 and product_categories.id = 6'])

谢谢你的时间

这样写,并传递一组要筛选的ID,怎么样

Product.joins(:product_categories).where(['product_categories.id in (?)', _product_categories_ids ])

这是选择男士和牛仔裤而不是男士或牛仔裤的解决方案:

@products = Product.scoped

@product_category_ids.each.with_index do |product_category_id, index|
  @products = @products.joins("INNER JOIN product_categories_products pcp#{index} ON pcp#{index}.product_id = products.id AND pcp#{index}.product_category_id = #{product_category_id}")
end

嗯,我发现这并不能解决我的问题。。如果我选择男士和牛仔裤。。我不要女式牛仔裤。。上面的代码就是这样的。。在我看来,这就像。。正确的?我需要。。我怎样才能做到这一点?谢谢