我在 2 个模型 superhero
和 superpower
之间有一个 Rails 连接表。现在我有 3 个不同的 superpower id
我想要所有 superheroes
都具有所有选定的 superpowers
为此,我正在尝试执行以下操作:
matches = Superhero.all
matches = matches.joins(:superpowers).where('superpowers.id = ?', 17).where('superpowers.id = ?', 12).where('superpowers.id = ?', 6)
但这给了我一个空对象,即使我有 superheroes
在我的连接表中有所有给定的 superpowers
从上面生成的查询是:
SELECT "superheroes".* FROM "superheroes" INNER JOIN "superheroes_superpowers" ON "superheroes_superpowers"."superhero_id" = "superheroes"."id" INNER JOIN "superpowers" ON "superpowers"."id" = "superheroes_superpowers"."superpower_id" WHERE (superpowers.id = 17) AND (superpowers.id = 17) AND (superpowers.id = 12) AND (superpowers.id = 6)
奇怪的是,它尝试检查 id 为 17 的 superpower
两次(但我认为它不应该影响结果)并且查询的其余部分似乎是正确的。
最佳答案
尝试使用 in 子句
superpowers_ids = [17,12,6]
matches = Superhero.all
matches = matches.joins(:superpowers).where('superpowers.id in (?)', superpowers_ids)
关于mysql - Rails 使用连接关联提取值,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46144962/