MySQL中DATEDIFF()函数用法及返回周、月、年
1.基本信息
在MySQL中,DATEDIFF 是一个日期函数,用于计算两个日期之间的差距,并以指定的时间单位返回结果。其函数形式如下列代码块所示:
DATEDIFF(end_date, start_date) end_date:表示要计算的时间段的结束日期。 start_date:表示要计算的时间段的开始日期。
注意:在MySQL中,DATEDIFF有且仅有两个参数,那就是结束时间和开始时间,不存在第一个参数为day,year这种的,那不是MySQL中的DATEDIFF函数!!!
返回值:DATEDIFF 函数返回一个整数,表示从start_date到end_date之间的天数差异,可以为负数。简单点来说就是前减去后,下面看一个例子:

2. 如何返回周、月、年
上面说到,DATEDIFF 函数返回一个整数,只能返回天数的差异,但是在实际的开发当中,你又不可能只返回天数,所以 这个时候我们就要适当的用向上向下取整函数以及除法来帮助我们返回年月了,先来举个例子,返回周:

可以看到结果为使用了向上取整函数后返回结果为3 ,那么具体是向上还是向下还是四舍五入,那就要看你具体的业务了,根据你具体的业务进行调整。
ROUND() 函数:用于将数值四舍五入到指定的小数位数。
FLOOR() 函数:用于将数值向下取整,去掉小数部分,保留整数部分。
CEIL() 或 CEILING() 函数:用于将数值向上取整,进位到最接近的整数。
扩展资料:
语法:DateDiff(interval, date1, date2 [,firstdayofweek][, firstweekofyear]])
DateDiff 函数的语法有以下参数:
- interval 必选。字符串表达式,表示用于计算 date1 和 date2 之间的时间间隔。有关数值,请参阅“设置”部分。
- date1, date2 必选。日期表达式。用于计算的两个日期。
- firstdayofweek 可选。指定星期中第一天的常数。如果没有指定,则默认为星期日。
- firstweekofyear 可选。指定一年中第一周的常数。如果没有指定,则默认为 1 月 1 日所在的星期。
总结
到此这篇关于MySQL中DATEDIFF()函数用法及返回周、月、年的文章就介绍到这了,更多相关MySQL DATEDIFF()函数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
linux下多个mysql5.7.19(tar.gz)安装图文教程
这篇文章主要为大家详细介绍了linux下多个mysql5.7.19tar.gz安装教程,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-07-07
批量清除128组节点db上面过期的binlog释放磁盘空间实现思路
在 一台db跳转机上面, 写一个脚本,访问slave,远程获取正在复制的master上面的binlog位置, 然后再远程去purge master上面的binlog2013-06-06
MySQL Aborted connection告警日志的分析
这篇文章主要介绍了MySQL Aborted connection告警日志的分析,帮助大家更好的理解和学习MySQL,感兴趣的朋友可以了解下2020-08-08


最新评论