前端之家收集整理的这篇文章主要介绍了
ruby-on-rails – Rails:返回不存在关系的记录,
前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
使用活动记录,如果模型中的某些关系不存在,则如何返回模型的结果.例如,假设我有一个属于类别的Recipe模型(通过category_recipes连接表).
所以基本上我有一个Rake任务,可以查看每个食谱及其描述,并尝试输入一个类别,但任务需要很长时间,我需要定期运行它,所以我只想运行如果相关的配方尚未被分类,我宁愿不添加像分类的多余列,所以我认为有一种方法只能检索连接表中不存在的配方.有什么想法吗?
您可以使用LEFT OUTER JOIN
解决此
查询:
Recipe.joins('LEFT OUTER JOIN recipe_categories ON recipes.id = recipe_categories.recipe_id').where('recipe_categories.recipe_id IS NULL')
原文链接:https://www.f2er.com/ruby/269393.html