我们在对数据查询或菜单时经常要对指定的时间或时间段进行查询,例如要查询一天内的信息,要查询一周内的信息,要查询一个月内的数据,这里我讲下DATE_SUB函数,同时结合实例进行讲解
type 参数可以是下列值:
现在,我们希望从 "OrderDate" 减去 2 天。
我们使用下面的 SELECT 语句:
3.复杂实例:
查询一天:
select * from table where to_days(column_time) = to_days(now());
select * from table where date(column_time) = curdate();
查询一周:
select * from table where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(column_time);
查询一个月:
select * from table where DATE_SUB(CURDATE(), INTERVAL 1 MONTH) <= date(column_time);
查询指定天数
定义和用法
DATE_SUB() 函数从日期减去指定的时间间隔。1.语法
DATE_SUB(date,INTERVAL expr type)date 参数是合法的日期表达式。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 |
简单实例
假设我们有如下的表:| OrderId | ProductName | OrderDate |
|---|---|---|
| 1 | 'Computer' | 2012-12-29 16:25:46.635 |
我们使用下面的 SELECT 语句:
SELECT OrderId,DATE_SUB(OrderDate,INTERVAL 2 DAY) AS OrderPayDate FROM Orders结果:
| OrderId | OrderPayDate |
|---|---|
| 1 | 2012-12-27 16:25:46.635 |
查询一天:
select * from table where to_days(column_time) = to_days(now());
select * from table where date(column_time) = curdate();
查询一周:
select * from table where DATE_SUB(CURDATE(), INTERVAL 7 DAY) <= date(column_time);
查询一个月:
select * from table where DATE_SUB(CURDATE(), INTERVAL 1 MONTH) <= date(column_time);
查询指定天数
select * from table where DATE_SUB(CURDATE(), INTERVAL 2 DAY) <= date(column_time);
SELECT * FROM Orders where DATE_SUB(CURDATE(),INTERVAL 2 WEEK) <= date(column_time)
就这么简单
也可以:
一天:
SELECT * FROM 表名 where 表字段>DATE_SUB(CURDATE(), INTERVAL 1 DAY)");
一周:
SELECT * FROM 表名 where 表字段>DATE_SUB(CURDATE(), INTERVAL 1 WEEK)");
一个月:
SELECT * FROM 表名 where 表字段>DATE_SUB(CURDATE(), INTERVAL 1MONTH");
本文介绍了MySQL中DATE_SUB函数的使用方法及其应用场景。DATE_SUB函数能够从指定日期减去一定的时间间隔,适用于各种时间范围的数据查询,包括一天内、一周内、一个月内等不同时间段的数据检索。
1433





