【问题标题】:sql, limiting the hourssql,限制时间
【发布时间】:2018-11-07 01:04:56
【问题描述】:

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

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(周六) 2 2 2 2 2 如果他在周六和周日工作 9 小时,那么额外的时间将按时间处理,否则会得到补偿。

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

【问题讨论】:

  • 能否请您详细说明您的问题,包括您想要的输出以及到目前为止您尝试过的内容!

标签: mysql sql datetime


【解决方案1】:

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

然后,您将小时数除以 2,得到两个不同的小时数。你可以使用mysql的HOUR()函数来实现。

完成后,您可以使用 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

Working SQL fiddle

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

这个答案主要是关于你的另一个被标记为重复的问题。

【讨论】:

    猜你喜欢
    • 2018-04-04
    • 2016-03-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2011-08-02
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多