1

嗨,我一直在研究一个简单的数据集,比如

no  Date                        time_in             time_out       extrahours
1   2018-05-01 00:00:00.0000000 09:00:00.0000000    18:50:00.0000000    0
1   2018-05-02 00:00:00.0000000 08:00:00.0000000    20:00:00.0000000    3
1   2018-05-03 00:00:00.0000000 09:50:00.0000000    19:50:00.0000000    1
1   2018-05-04 00:00:00.0000000 07:00:00.0000000    17:45:00.0000000    1
1   2018-05-05 00:00:00.0000000 09:15:00.0000000    13:50:00.0000000    -5
1   2018-05-06 00:00:00.0000000 08:45:00.0000000    23:55:00.0000000    6
1   2018-05-07 00:00:00.0000000 12:00:00.0000000    23:00:00.0000000    2
1   2018-05-08 00:00:00.0000000 02:30:00.0000000    23:55:00.0000000    12
1   2018-05-09 00:00:00.0000000 10:50:00.0000000    19:50:00.0000000    0
1   2018-05-10 00:00:00.0000000 08:36:00.0000000    19:50:00.0000000    2

我被要求将最多加班时间限制在 2 以内,即加班时间必须在(周六或周日)的周末得到补偿

加班时间 0 0 0 0 0(sat) 2 2 2 2 2 如果他在周六和周日工作 9 小时,则加班时间将被处理,否则将获得补偿。

请花点时间回答我的问题,谢谢。

4

1 回答 1

0

你需要做的是做一个CASE WHEN, 看看你的小时数是否可以被 2 整除,只要它们大于 0,它们就应该是 2。

然后你把你的小时数除以 2 得到两个不同的小时数。您可以使用 mysqlHOUR()功能来实现这一点。

完成后,您使用该SEC_TO_TIME()函数将结果转换回时间并相应地相乘以获得您想要的任何时间格式,60 分钟,然后另一个 60 小时。

我使用该MINUTE()函数来获取分钟,并继续使用与小时相同的方法。

我想出了这样的事情:

SELECT
  empNo,
  (
    CASE
      WHEN
        extraHours > 0
      THEN
        SEC_TO_TIME(((HOUR(extraHours) / 2)*60)*60)
      END) as otOne,
  (
    CASE
      WHEN
        extraHours > 0
      THEN
        SEC_TO_TIME(((HOUR(extraHours) / 2)*60)*60)
      END) as otTwo,
  SEC_TO_TIME(MINUTE(extraHours)*60) as otThree
FROM
  tbl_time

工作 SQL 小提琴

如果您想要一个带有秒数的额外字段,您只需使用相同的方法,并使用该SECOND()函数。

该答案主要与您的其他被标记为重复的问题有关。

于 2018-05-30T08:17:57.293 回答