sql时间交集
发布时间: 2024-02-02 14:26:20
⑴ sql合并多个时间段
如果是oracle 我会使用一个临时表,包含人员,持续开始时间,持续结束时间,处理任务,处理方法如下
首先取出某员工一天的所有工作记录,按开始时间排序后逐条处理
首先将第一条记录插入到临时表中,持续开始时间为 开始时间,持续结束时间为结束时间,处理任务为1;
在取到后续记录时,作如下处理
如果开始时间 > 临时表中已经存在的所有结束时间,则新增一条记录,与第一条处理方式一致;
如果开始时间 <=临时表中已经存在的某一结束时间处理如下
如果 结束时间 <=临时表中已经存在的某一结束时间,不作任何插入和更新;
如果 结束时间 >临时表中已经存在的某一结束时间,更新临时表中对应记录为当前取到的结束时间;
按照以上规则直至所有数据均处理完成,此时临时表中获得的是不重叠的所有工作时间,采用group 即可获得一天是实际工作时间,进而可以求出休息时间。
热点内容