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

sql时间交集

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

sql合并多个时间段

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

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

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

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

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

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

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

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

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

热点内容
微信青少年模式独立密码是什么 发布:2025-01-22 16:52:06 浏览:587
腾讯云服务器怎么购买 发布:2025-01-22 16:45:01 浏览:628
天猫怎么上传视频 发布:2025-01-22 16:40:02 浏览:725
安卓如何把抖音评论换成黑色 发布:2025-01-22 16:30:57 浏览:700
连接池Java 发布:2025-01-22 16:28:27 浏览:258
抢杠算法 发布:2025-01-22 16:15:02 浏览:72
图片服务器ftp 发布:2025-01-22 15:52:33 浏览:507
sql打开bak文件 发布:2025-01-22 15:47:32 浏览:107
opengl服务器源码 发布:2025-01-22 15:40:02 浏览:909
python部署服务 发布:2025-01-22 15:38:46 浏览:283