在MySQL 中選擇今天到過去30 天的記錄
在MySQL 中,您可以使用以下命令來擷取指定日期範圍內的指令擷取記錄如下所示的查詢:
SELECT * FROM table_name WHERE date_column BETWEEN start_date AND end_date
但是,當嘗試將結果限制為前一個時30天后,使用者可能會遇到查詢傳回所有記錄的問題。要解決此問題,了解正確的日期格式語法至關重要。
在提供的查詢中:
create_date between DATE_FORMAT(curdate(),'%m/%d/%Y') AND (DATE_FORMAT(curdate() - interval 30 day,'%m/%d/%Y'))
WHERE 子句中錯誤地使用了 DATE_FORMAT 函數。應在 SELECT 子句中套用此函數,以格式化檢索到的日期以供顯示:
SELECT DATE_FORMAT(create_date, '%m/%d/%Y') AS formatted_date FROM table_name WHERE create_date BETWEEN CURDATE() - INTERVAL 30 DAY AND CURDATE()
此外,考慮 create_date 列的資料類型也很重要。如果將其儲存為具有非零時間分量的 DATETIME,則上述查詢將無法準確選擇今天的記錄。在這種情況下,請使用NOW() 代替:
SELECT DATE_FORMAT(create_date, '%m/%d/%Y') AS formatted_date FROM table_name WHERE create_date BETWEEN NOW() - INTERVAL 30 DAY AND NOW()
透過應用這些更正,查詢將正確檢索在指定30 天範圍內建立的記錄,格式為所需的「mm/dd /yy”格式。
以上是如何選擇最近30天(包括今天)的MySQL記錄?的詳細內容。更多資訊請關注PHP中文網其他相關文章!