首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >替代Model.all -Model.where(条件)

替代Model.all -Model.where(条件)
EN

Stack Overflow用户
提问于 2019-09-15 22:35:43
回答 2查看 67关注 0票数 0

我的问题很简单:如何优化以下查询以避免数据库增长时出现性能问题:

代码语言:javascript
复制
def projects_not_participating
  @project = Project.all - Project.joins(:participants).where(participant: {id: current_user.id})
end

我的模型设置如下:

代码语言:javascript
复制
def Project
  has_many :assignments
  has_many :participants, through: :assignments
end
代码语言:javascript
复制
def Participant
  has_many :assignments
  has_many :projects, through: assignments
end

我试着用

代码语言:javascript
复制
Project.joins(:participant).where.not(participant: {id: current_user.id})

但这还了所有的项目。我发现查询正在返回assignments中的所有表条目,其中participant_id不是current_user.id,并且没有对项目条目进行分组。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-09-18 22:37:23

我终于找到了解决办法。我向我的Project类添加了一个方法:

代码语言:javascript
复制
def self.not_participating(user)
  where.not(id: user.projects)
end

并在我的User控制器中使用:

代码语言:javascript
复制
def find_projects
  @projects = Project.not_participating(current_user)
end
票数 0
EN

Stack Overflow用户

发布于 2019-09-16 08:37:01

实际上,你离解决方案很近。目前的问题是重复项目。为了避免这种情况,可以使用distinct

代码语言:javascript
复制
Project.joins(:participants).where.not(participants: {id: current_user.id}).distinct
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/57948673

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档