我有表格来存储我的员工的出勤数据,如下所示:
EmployeeID| Date |EnterTime|ExitTime|
1 |2017-01-01|07:11:00 |15:02:00|
2 |2017-01-01|07:30:00 |12:00:00|
2 |2017-01-02|07:00:00 |15:00:00|
1 |2017-01-02|07:30:00 |10:00:00|
1 |2017-01-02|11:20:00 |15:00:00|
1 |2017-01-03|09:30:00 |10:00:00|
1 |2017-01-03|11:20:00 |15:00:00|
实际上我的工作时间是从 07:00:00 到 15:00:00 。
我想总结一下每个员工的缺勤时间,例如:员工 ID 2 的 2017-01-01 是 03:00:00 缺勤时间,员工 ID 1 的日期 2017-01-02 是 01:00 :00 小时。在 Date 2017-01-03 中,员工 id 1 是 02:30:00,员工 id 2 缺勤时间是 08:00:00,因为我的表中没有日志。最后需要以下报告:
EmployeeID|TotalWorkingHour |TotalAbsenceHour|
1 |sum(EnterTime-ExitTime)|05:09:00 |
2 |sum(EnterTime-ExitTime)|11:30:00 |
我通过以下选择获得总工作秒数,但不知道如何计算缺勤秒数:
select EmployeeID,
sum(datediff(second,Convert(DATETIME, EnterTime, 114), Convert(DATETIME, ExitTime, 114)) ) as TotalWorkingSeconds
from Attendance
where Attendance.Date between @FromDate and @ToDate
and (EnterTime is not null)
and (ExitTime is not null)
group by EmployeeID