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)
| 归档时间: |
|
| 查看次数: |
6147 次 |
| 最近记录: |