我有以下代码,并想将请求转换为 mysql 查询。现在,我在数据上使用手动 .select (数组方法)实现了预期的结果。这应该可以通过单个查询来实现(如果我错了,请纠正我)。
当前代码:
def self.active_companies(zip_code = nil)
if !zip_code
query = Company.locatable.not_deleted
else
query = Company.locatable.not_deleted.where("zip_code = ?", zip_code)
end
query.select do |company|
company.company_active?
end
end
# Check if the company can be considered as active
def company_active?(min_orders = 5, last_order_days_ago = 15)
if orders.count >= min_orders &&
orders.last.created_at >= last_order_days_ago.days.ago &&
active
return true
else
return false
end
end
解释: 我想知道哪些公司是活跃的。我们有公司模式和订单模式。
数据: 公司:
- 积极的
- 订单(关联订单)
订单:
- created_at