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()
函数结果一样。