首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >从查询中获取最繁忙的员工

从查询中获取最繁忙的员工
EN

Stack Overflow用户
提问于 2016-06-08 14:12:59
回答 1查看 53关注 0票数 0

我有两个模特:

代码语言:javascript
运行
复制
# Table name: work_schedules
#
#  id          :integer          not null, primary key
#  start_time  :time             not null
#  end_time    :time             not null
#  day_of_week :string           not null
#  updated_at  :datetime         not null
#  person_id   :integer

# Table name: people
#
#  id                         :integer          not null, primary key
#  pesel                      :string           not null
#  first_name                 :string           not null
#  last_name                  :string           not null

我要找最忙的员工查询。首先,我应该计算小时数(end_time- start_time)和计数day_of_week(唯一属性范围: person_id)。我不知道如何创建正确的查询。我试过的是:

代码语言:javascript
运行
复制
@most_busy = Person.joins(:work_schedules).where(%q{end_time - start_time}).first
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-06-08 14:28:58

适用于一周中的任何一天(即一周中所有日子的总结):WorkSchedule.group(:person_id).sum('extract(epoch from work_schedules.end_time) -extract(epoch from work_schedules.start_time)').sort_by { |_,v| -v}.first.first

这将给出在整个WorkSchedules中工作最多的人的ID。我只用PostgreSQL测试过它。

在这个查询中发生了什么:

  1. 获取所有工作计划对象,并按人员ids对其进行分组。
  2. 对于每一组工作计划,获取开始时间和结束时间之间的差异之和。从提取的时代告诉SQL将时间戳作为整数(我相信是UNIX时间戳)。这是必要的,因为否则查询的结果会将这些和作为字符串,例如"17天136:57:42.748124“,而ruby不能正确地排序。
  3. SQL查询将导致表单{person_id: time_scheduled_in_seconds}的散列。
  4. sort_by对查询进行反向排序。我们不使用散列中的键,所以我们使用下划线而不是名称来忽略它们。
  5. 然后,我们接受这个散列中的第一个项(因此是第一个".first")。
  6. 因为这实际上返回了一个数组,其中person_id作为第一个值,秒数作为第二个值,所以我们只保留第一个项(因此是第二个".first")。
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37704990

复制
相关文章

相似问题

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