在我的Ruby on Rails应用程序,我有以下型号:ActiveRecord的 - 查找记录,它的关联计数为0
class SlideGroup < ApplicationRecord
has_many :survey_group_lists, foreign_key: 'group_id'
has_many :surveys, through: :survey_group_lists
end
我想找到所有孤立的幻灯片组。孤立幻灯片组是与任何调查无关的幻灯片组。我一直试图下面的查询,但它不返回任何东西,我敢肯定,我在我的测试数据库中的孤立记录:
SlideGroup.joins(:surveys).group("slide_groups.id, surveys.id").having("count(surveys.id) = ?",0)
这会产生下面的SQL查询:
SlideGroup Load (9.3ms) SELECT "slide_groups".* FROM "slide_groups" INNER JOIN "survey_group_lists" ON "survey_group_lists"."group_id" = "slide_groups"."id" INNER JOIN "surveys" ON "surveys"."id" = "survey_group_lists"."survey_id" GROUP BY slide_groups.id, surveys.id HAVING (count(surveys.id) = 0)
这里你需要一个'outer join',因为'inner join'不会返回孤儿。 – mudasobwa