1.格式化时间
date_format(字段名,'%x年%m月%d日 %H:%i:%S') 别名 (注意:字段名也可以是now(),也就是当前时间)
我一般是使用上面的方法对查询时间进行格式化,例子:
2.使用MySQL自带的DATE_ADD() 函数
定义和用法
DATE_ADD() 函数向日期添加指定的时间间隔。
语法
DATE_ADD(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' | 2008-12-29 16:25:46.635 |
现在,我们希望向 "OrderDate" 添加 2 天,这样就可以找到付款日期。
我们使用下面的 SELECT 语句:
SELECT OrderId,DATE_ADD(OrderDate,INTERVAL 2 DAY)
AS OrderPayDate
FROM Orders
结果:
OrderId | OrderPayDate |
---|---|
1 | 2008-12-31 16:25:46.635 |
我的项目中就用到查询最近3天的记录,如下:
SELECT
avg(cistern_liquid_level_min) minWaterMeterAvg
FROM
heat_device_data_record_statistics
WHERE
day_time >= date_format(date_add(now(), INTERVAL - 3 DAY),'%Y-%m-%d 00:00:00')
AND day_time <= date_format(now(), '%Y-%m-%d 00:00:00')
AND mark_code = 'Z14';
3.使用timestampdiff函数
语法:
TIMESTAMPDIFF(interval,datetime_expr1,datetime_expr2)。
说明:
返回日期或日期时间表达式datetime_expr1 和datetime_expr2the 之间的整数差。其结果的单位由interval 参数给出。该参数必须是以下值的其中一个:
- FRAC_SECOND。表示间隔是毫秒
- SECOND。秒
- MINUTE。分钟
- HOUR。小时
- DAY。天
- WEEK。星期
- MONTH。月
- QUARTER。季度
- YEAR。年
用于MySQL自带计算时间的功能,比如查询距离现在不超过24小时的数据
SELECT * FROM `heat_device_group_rela` r WHERE TIMESTAMPDIFF(HOUR,r.update_time,NOW()) < 24;
SELECT TIMESTAMPDIFF(MONTH,'2009-09-01','2009-12-01'); 如果两个时间位置换一下那么就输出-3