Rails:返回不存在关系的记录

JP *_*shy 8 activerecord ruby-on-rails

使用活动记录,如果模型中的某些关系存在,则如何返回模型的结果.例如,假设我有一个Recipe属于categories(通过category_recipes连接表)的模型.

所以基本上我有一个Rake任务,可以查看每个食谱及其描述,并尝试输入一个类别,但任务需要很长时间,我需要定期运行它,所以我只想运行如果Recipe问题尚未被分类,我宁愿不添加多余的列categorized,所以我认为有一种方法只能检索连接表中不存在的食谱.有什么想法吗?

Jas*_*red 15

您可以使用以下命令解决此查询LEFT OUTER JOIN:

Recipe.joins('LEFT OUTER JOIN recipe_categories ON recipes.id = recipe_categories.recipe_id').where('recipe_categories.recipe_id IS NULL')
Run Code Online (Sandbox Code Playgroud)


小智 13

不得不今天自己解决这个问题,并认为这将解决这个问题:

Recipe.includes(:categories).where('categories.id IS NULL').references(:categories)
Run Code Online (Sandbox Code Playgroud)