MySQL SUBTIME() 函数使用指南
MySQL SUBTIME() 函数在指定的时间上减去指定的时间间隔并返回结果。
SUBTIME() 语法
这是 MySQL SUBTIME() 函数的语法:
SUBTIME(timeExpr1, timeExpr2)
参数
timeExpr1- 必需的。它是一个 datetime 或者 time 表达式。
timeExpr2- 必需的。它是个时间表达式。它可以是正数或者负数。
返回值
SUBTIME() 函数从 timeExpr1 中减去 timeExpr2,并返回结果。
SUBTIME() 函数按如下规则确定返回值的类型:
- 如果
timeExpr1参数是动态类型,SUBTIME()函数返回值类型为TIME。 - 否则,
SUBTIME()函数返回的数据类型和第一个参数一样。
SUBTIME() 示例
这里是几个 SUBTIME() 函数的示例。
示例 1
给指定的时间减去 10 秒钟:
SELECT
SUBTIME('2020-10-10 10:10:10', 10),
SUBTIME('10:10:10', 10)\G
SUBTIME('2020-10-10 10:10:10', 10): 2020-10-10 10:10:00
SUBTIME('10:10:10', 10): 10:10:00示例 2
给指定的时间减去 1 分钟:
SELECT
SUBTIME('10:10:10', 100),
SUBTIME('10:10:10', '100'),
SUBTIME('10:10:10', '0:01:00')\G
SUBTIME('10:10:10', 100): 10:09:10
SUBTIME('10:10:10', '100'): 10:09:10
SUBTIME('10:10:10', '0:01:00'): 10:09:10示例 3
给指定的时间减去和加上 1 小时 10 分钟 10 秒 10 微秒。
SELECT
SUBTIME('10:00:00', '01:10:10.000010'),
SUBTIME('10:00:00', '-01:10:10.000010'),
ADDTIME('10:00:00', '01:10:10.000010')\G
SUBTIME('10:00:00', '01:10:10.000010'): 08:49:49.999990
SUBTIME('10:00:00', '-01:10:10.000010'): 11:10:10.000010
ADDTIME('10:00:00', '01:10:10.000010'): 11:10:10.000010这里,参数 '-01:10:10.000010' 前面的减号意味着从 '10:00:00' 上减去 '01:10:10.000010',这和 ADDTIME() 函数结果一样。