繁体   English   中英

Rails查询,该查询返回所有记录,这些记录具有与条件完全相关的零记录

[英]Rails query which returns all records having exactly ZERO associated record with condition

这是我的关联:

class Insights::Visitor < ActiveRecord::Base
  has_many :conversations,
    class_name: "Chat::Conversation",
    foreign_key: :chat_visitor_id
end

class Chat::Conversations < ActiveRecord::Base
  belongs_to :chat_visitor,
      class_name: "Insights::Visitor",
      foreign_key: "chat_visitor_id"

   enum status: {
      open: "open",
      closed: "closed",
      pending:  "pending",
      spam:  "spam",
      trash: "trash"
    }
end

我的用例非常简单。 我想在没有任何打开的对话或访问者模型的范围的情况下获得访问者计数,该模型将返回所有具有零关联的对话且状态为“打开”的访问者。

目前,我主要使用Ruby来完成此操作,如下所示:

def visitor_count_without_open_conversations
    online_visitors = organization.visitors.includes(:conversations).online
    count = 0
    online_visitors.each do |visitor|
      if visitor.conversations.search_with_status("open").size == 0
        count +=1
      end
     end 
    return count
  end
end

很烂,因为这不是Ruby的好用例。 但是我正在努力弄清楚如何使用SQL做到这一点。

有人可以让我知道一个很好的,干净的SQL解决方案吗?

这是我的关联:

class Insights::Visitor < ActiveRecord::Base
  has_many :conversations,
    class_name: "Chat::Conversation",
    foreign_key: :chat_visitor_id
end

class Chat::Conversations < ActiveRecord::Base
  belongs_to :chat_visitor,
      class_name: "Insights::Visitor",
      foreign_key: "chat_visitor_id"

   enum status: {
      open: "open",
      closed: "closed",
      pending:  "pending",
      spam:  "spam",
      trash: "trash"
    }
end

我的用例非常简单。 我想在没有任何打开的对话或访问者模型的范围的情况下获得访问者计数,该模型将返回所有具有零关联的对话且状态为“打开”的访问者。

目前,我主要使用Ruby来完成此操作,如下所示:

def visitor_count_without_open_conversations
    online_visitors = organization.visitors.includes(:conversations).online
    count = 0
    online_visitors.each do |visitor|
      if visitor.conversations.search_with_status("open").size == 0
        count +=1
      end
     end 
    return count
  end
end

很烂,因为这不是Ruby的好用例。 但是我正在努力弄清楚如何使用SQL做到这一点。

有人可以让我知道一个很好的,干净的SQL解决方案吗?

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM