前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

前端大佬問我後端小白查最近10分鐘的資料,一開始我想到的是直接用between and或者<>就可以了,但是可能是想要最近的10分鐘,那麼這個數就不太好寫清楚,只能是當前時間-10分鐘這種操作,對於mysql的一些操作也忘記了,於是找了篇文章,並且自己把sql都執行了一遍,瞭解了新的sql查詢。希望本篇文章可以幫助到你,關於Mysql日期方面的知識~

歸納

1. 查詢時間段內的資料,一般可以用between and 或者 <>來指定時間段

2. mysql的時間欄位型別有:dateTime, timestamp,data,time,year

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

3.獲取系統當前時間的函式:

select CURDATE();select NOW();

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

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)

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

將TIMEDIFF函式返回的TIME值轉換為天數,小時格式

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

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`;

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

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`; # 減一小時一分一秒

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

ADDTIME的測試

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

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函式的測試

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

可以使用的格式有:

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的

2021最新完整面試題及答案(都整理成文件),有很多幹貨,包含mysql,netty,spring,執行緒,spring cloud、JVM、原始碼、演算法等詳細講解,詳細的學習規劃圖等學習資料,私信我:Java 獲取!

前端大佬問我MySQL怎麼查詢最近10分鐘的資料?我是這麼回答他的