MySQL 學習筆記: 查找最近 3 個月的數據
前言
MySQL 是開源免費的關系型數據庫管理系統,是現今互聯網應用最廣泛的開源數據庫之一。對于一些數據分析需求,我們需要查詢最近3個月的數據。這篇文章介紹如何使用 MySQL 的內置函數和語句優化實現這個功能。
使用 NOW() 函數取當前日期
MySQL 中的 NOW() 函數可以獲取當前的系統日期和時間,可以用使用以下語句獲取:SELECT NOW();
如果我們想獲取最近3個月的日期,可以使用 DATE_SUB() 函數將當前日期向前推3個月。DATE_SUB(date, INTERVAL expr unit),其中 date 是日期,expr 是一個正整數,可以理解為向前推的時間,unit 表示時間單位,例如 DAY, WEEK, MONTH 或 YEAR。所以,獲取最近3個月的日期需要使用以下語句:SELECT DATE_SUB(NOW(), INTERVAL 3 MONTH);
使用 BETWEEN 子句篩選數據
有了最近3個月的日期,我們就可以使用 BETWEEN 子句篩選出對應的數據了。BETWEEN 子句可以使用在 WHERE 或 HAVING 子句中,它將返回數據在一個指定的范圍內。
比如我們有一個表 orders,里面有創建日期 create_time,我們可以查詢最近3個月之內的訂單,使用以下語句:SELECT * FROM orders WHERE create_time BETWEEN DATE_SUB(NOW(), INTERVAL 3 MONTH) AND NOW();
優化查詢性能
如果表 orders 的數據非常大,使用上述語句可能會非常緩慢,影響性能。因此,我們可以為 create_time 字段添加索引,加快查詢速度。索引的創建語句為:ALTER TABLE orders ADD INDEX order_create_time_idx(create_time);
經過測試,添加索引后查詢耗費的時間大幅度減少,這是查詢優化的常見手段之一。
結語
本文介紹了如何使用 MySQL 的內置函數和語句優化實現查詢最近3個月的數據。還介紹了索引的作用和創建方法,以提升查詢性能。了解這些知識點對于優化查詢有很大的幫助。