mysql中时间计算函数SQL DATE_SUB()用法

本文介绍了一个实用的SQL函数DATE_SUB(),它能简化日期/时间值的计算过程。通过几个例子展示了如何使用此函数来计算不同时间间隔之前的日期。

本文为博主原创,未经允许不得转载:

      在写sql的时候,经常要在sql中传值时间,对时间进行计算并过滤。之前都是将时间在后台计算好,直接传值给sql,

今天发现,有一个更方便的sql函数,可以简化很多代码。这个函数就是 DATE_SUB()。

      DATE_SUB 将从一个日期/时间值中减去一个时间值(时间间隔)。

      其函数中用法表达式为:DATE_SUB(date,INTERVAL expr type),

type的参数可以为一下类型:

MICROSECOND
SECOND
MINUTE
HOUR
DAY
WEEK
MONTH
QUARTER
YEAR
SECOND_MICROSECOND
MINUTE_MICROSECOND
MINUTE_SECOND
HOUR_MICROSECOND
HOUR_SECOND
HOUR_MINUTE
DAY_MICROSECOND
DAY_SECOND
DAY_MINUTE
DAY_HOUR
YEAR_MONTH

使用举例如下:

--一年前
select DATE_SUB(CURDATE(), INTERVAL 1 YEAR) as yearTime 
--一天前
select DATE_SUB(CURDATE(), INTERVAL 1 DAY) as selecttime 
--一月前
select DATE_SUB(CURDATE(), INTERVAL 1 MONTH) as selecttime 
--三年前
select DATE_SUB(CURDATE(), INTERVAL 3 YEAR) as yearTime 
  1. SELECT DATE_SUB('2010-08-12', INTERVAL 3 DAY) AS NewDate  

结果: 2010-08-09

2.SELECT DATE_SUB('2010-08-12', INTERVAL '3-2' YEAR_MONTH) AS NewDate  

结果: 2007-06-12

3.SELECT DATE_SUB('2011-09-14 2:44:36', INTERVAL '2:26' HOUR_MINUTE) AS NewDate  

结果: 2011-09-14 00:18:36

在 Presto SQL 中,`date_add` 和 `date_sub` 是两个常用的日期函数,用于对日期进行加减操作。这些函数可以用于 `DATE` 类型或者 `TIMESTAMP` 类型的数据,支持对年、月、日、小时、分钟等时间单位进行操作。 ### `date_add` 函数 `date_add` 函数用于向指定日期添加一定的时间间隔。其基本语法如下: ```sql date_add(unit, value, timestamp) ``` - `unit`:表示时间单位,例如 `YEAR`, `MONTH`, `DAY`, `HOUR`, `MINUTE` 等。 - `value`:表示要添加的数值。 - `timestamp`:表示输入的日期或时间戳。 例如,向当前日期添加 5 天: ```sql SELECT date_add('DAY', 5, CURRENT_DATE); ``` 此查询将返回当前日期加上 5 天后的日期。 向某个日期添加 2 小时: ```sql SELECT date_add('HOUR', 2, TIMESTAMP '2023-10-01 12:00:00'); ``` 此查询将返回 `2023-10-01 14:00:00`。 ### `date_sub` 函数 `date_sub` 函数用于从指定日期减去一定的时间间隔。其基本语法与 `date_add` 类似: ```sql date_sub(unit, value, timestamp) ``` - `unit`:表示时间单位。 - `value`:表示要减去的数值。 - `timestamp`:表示输入的日期或时间戳。 例如,从当前日期减去 3 天: ```sql SELECT date_sub('DAY', 3, CURRENT_DATE); ``` 此查询将返回当前日期减去 3 天后的日期。 从某个日期减去 1 小时: ```sql SELECT date_sub('HOUR', 1, TIMESTAMP '2023-10-01 12:00:00'); ``` 此查询将返回 `2023-10-01 11:00:00`。 ### 结合表查询使用 这些函数也可以用于表中的列。假设有一个表 `orders`,其中包含 `order_date` 列,类型为 `DATE`。 查询所有订单日期加上 7 天的结果: ```sql SELECT order_id, date_add('DAY', 7, order_date) AS new_order_date FROM orders; ``` 查询所有订单日期减去 2 天的结果: ```sql SELECT order_id, date_sub('DAY', 2, order_date) AS adjusted_order_date FROM orders; ``` ### 注意事项 - `date_add` 和 `date_sub` 函数支持的时间单位包括 `YEAR`, `MONTH`, `DAY`, `HOUR`, `MINUTE`, `SECOND` 等。 - 如果输入的是 `DATE` 类型,结果将自动转换为 `DATE` 类型;如果是 `TIMESTAMP` 类型,结果将保留时间部分。 - Presto SQL 的日期函数处理逻辑与某些其他 SQL 方言(如 MySQL 或 PostgreSQL)略有不同,需注意时间单位的大小写和参数顺序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值