网站首页 > 基础教程 正文
前端大佬问我后端小白查最近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/dd
datediff(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_MONTH
DATE_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)的测试
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函数的测试
可以使用的格式有:
2021最新完整面试题及答案(都整理成文档),有很多干货,包含mysql,netty,spring,线程,spring cloud、JVM、源码、算法等详细讲解,详细的学习规划图等学习资料,私信我:Java 获取!
猜你喜欢
- 2024-11-07 VBA编程,利用DatePart函数获取特定日期
- 2024-11-07 MySQL引起的CPU消耗过大,你会如何优化?
- 2024-11-07 高级数据分析师必备SQL常用处理函数,我觉得收藏是必须的
- 2024-11-07 每日SQL自学知识点(第三天)—lead的窗口函数、datediff函数
- 2024-11-07 mysql与时间有关的查询 mysql与时间有关的查询方法
- 2024-11-07 面试官:如何正确的清理Mysql数据库binlog日志?
- 2024-11-07 数据库丨从MySQL数值隐式转换成了double型的测试点,值得学习
- 2024-11-07 限定Excel数据使用时间,到期自动销毁,这2种方法都能轻松搞定
- 2024-11-07 关于Mysql数据库清理binlog日志命令总结
- 2024-11-07 「MySQL入门」快来看看MySQL函数就是这么简单
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)