当前位置:首页 » 编程语言 » sql时间交集

sql时间交集

发布时间: 2024-02-02 14:26:20

sql合并多个时间段

如果是oracle 我会使用一个临时表,包含人员,持续开始时间,持续结束时间,处理任务,处理方法如下

  • 首先取出某员工一天的所有工作记录,按开始时间排序后逐条处理

  • 首先将第一条记录插入到临时表中,持续开始时间为 开始时间,持续结束时间为结束时间,处理任务为1;

  • 在取到后续记录时,作如下处理

  • 如果开始时间 > 临时表中已经存在的所有结束时间,则新增一条记录,与第一条处理方式一致;

  • 如果开始时间 <=临时表中已经存在的某一结束时间处理如下

  • 如果 结束时间 <=临时表中已经存在的某一结束时间,不作任何插入和更新;

  • 如果 结束时间 >临时表中已经存在的某一结束时间,更新临时表中对应记录为当前取到的结束时间;

  • 按照以上规则直至所有数据均处理完成,此时临时表中获得的是不重叠的所有工作时间,采用group 即可获得一天是实际工作时间,进而可以求出休息时间。

热点内容
c语言打开网页 发布:2025-07-15 05:21:33 浏览:640
如何制作我的世界模组服务器 发布:2025-07-15 05:21:33 浏览:903
phparray加 发布:2025-07-15 05:20:41 浏览:782
4000以内二手安卓机怎么选 发布:2025-07-15 05:11:25 浏览:643
静态编译修复器 发布:2025-07-15 05:11:24 浏览:506
iphonexr的存储空间 发布:2025-07-15 05:09:20 浏览:328
能缓存航海王 发布:2025-07-15 04:55:38 浏览:90
安卓手机投屏为什么只能本地视频 发布:2025-07-15 04:51:19 浏览:537
栈的存储结构 发布:2025-07-15 04:51:16 浏览:234
现在天龙八部脚本 发布:2025-07-15 04:45:35 浏览:333