前端大佬问我后端小白查最近10分钟的数据,一开始我想到的是直接用between and或者<>就可以了,但是可能是想要最近的10分钟,那么这个数就不太好写清楚,只能是当前时间-10分钟这种操作,对于MySQL的一些操作也忘记了,于是找了篇文章,并且自己把sql都执行了一遍,了解了新的sql查询 。希望本篇文章可以帮助到你,关于Mysql日期方面的知识~
归纳1. 查询时间段内的数据,一般可以用between and 或者 <>来指定时间段
2. mysql的时间字段类型有:dateTime,timestamp,data,time,year
文章插图
3.获取系统当前时间的函数:
select CURDATE();select NOW();
文章插图
4.获取时间差的函数:period的翻译为“时期”
# 计算月份:其中p1, p2 的格式为YYMM 或者YYYYMM period_diff(p1, p2)# 计算天数:其中d1, d2 的格式为YY-MM-dd 或者YYYY-MM-dd或者YY/MM/dd或者YYYY/MM/dddatediff(d1, d2)# 计算时间: 其中t1, t2的格式为yyyy-MM-dd HH:mm:ss,或者 HH:mm:ss等 格式不同会返回null#注意:因为TIMEDIFF函数返回TIME值,所以其结果被限制在从-838:59:59到838:59:59的TIME值范围内timediff(t1, t2)
文章插图
文章插图
将TIMEDIFF函数返回的TIME值转换为天数,小时格式
文章插图
5.日期加减函数
# date 参数是合法的日期表达式 expr 参数是您希望添加的时间间隔 。# type 参数可以是下列值:# MICROSECOND SECOND MINUTE HOUR DAY WEEK MONTH QUARTER YEAR # SECOND_MICROSECOND MINUTE_MICROSECOND MINUTE_SECOND # HOUR_MICROSECOND HOUR_MINUTE HOUR_SECOND # DAY_MICROSECOND DAY_SECOND DAY_MINUTE DAY_HOUR# YEAR_MONTHDATE_SUB(date,INTERVAL expr type)# 与DATE_SUB同理DATE_ADD(date,INTERVAL expr type)# 与DATE_ADD的作用相同 如 SELECT ADDDATE('2021-05-20 13:14:52',INTERVAL 1 SECOND);ADDDATE()# 详情见测试案例ADDTIME()# 增加N个月至周期P (格式为YYMM或YYYYMM) 。返回格式为YYYYMM的值 。注意:周期参数P不是日期值period_add(P, N)
DATE_SUB 的测试SELECT DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 YEAR) AS `date_sub_year`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 QUARTER) AS `date_sub_quarter`, # 减6个月DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 MONTH) AS `date_sub_month`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 WEEK) AS `date_sub_week`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL '2:2' DAY_SECOND) AS `date_sub_day`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 HOUR_SECOND) AS `date_sub_hour`, DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 MINUTE) AS `date_sub_minute`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL 2 SECOND) AS `date_sub_second`,DATE_SUB("2021-05-20 13:14:52.099",INTERVAL '1:1' SECOND_MICROSECOND) AS `date_sub_microsecond`;
文章插图
SELECT DATE_SUB('2021-05-20 13:14:52',INTERVAL '1:1' MINUTE_SECOND) AS `date_sub_minute_second`, # 减一分一秒DATE_SUB('2021-05-20 13:14:52',INTERVAL '1:1:1' HOUR_SECOND) AS `date_sub_hour_second`; # 减一小时一分一秒
文章插图
ADDTIME的测试
文章插图
PERIOD_ADD(P, N)的测试
文章插图
【前端大佬问我MySQL怎么查询最近10分钟的数据?我是这么回答他的】
6.时间格式转化函数:
# mysql 日期格式化函数DATE_FORMAT()DATE_FORMAT(date,format)unix_timestamp()str_to_date(str, format)# mysql时间戳格式化函数 from_unixtime()from_unixtime(unix_timestamp, format)
DATE_FORMAT函数的测试文章插图
可以使用的格式有:
文章插图
推荐阅读
- 对前端、后端和全栈感兴趣的人,建议都看看!18年老程序员忠告
- 前端老弟第一次写后端,崩了
- Bootstrap5.0-全球流行的前端开源UI工具包迎来了大版本更新
- 推荐几个抓包类工具的下载
- 你问我为什么喜欢二次元?喜欢我二次元吗
- vscode 前端常用插件推荐
- 跑鞋|花300万买双假鞋!现在的大佬都玩得这么野?
- npm简介
- 低成本可复用前端框架——Linke
- 前端工作量大还是后台工作量大?