前端大佬問我后端小白查最近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函數的測試
可以使用的格式有: