勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

MySQLで直近〇日、〇ヶ月、〇年以内のデータを検索する方法

  MySQL データベース

他社が作成されたSQL文を見ているとDATE_ADDという使ったことの無い関数が見受けられた。内容的には直近〇日のデータを検索する、といったSQL文みたい。自分の場合だとPHP側で〇日前の日付を計算して「ymd >= yyyy-mm-dd」みたいに書くが、DATE_ADD関数を使った方がスマートそう。以下に使い方のメモ。

 

リファレンス

https://dev.mysql.com/doc/refman/8.0/ja/date-and-time-functions.html#function_date-add

 

データベース構造

mysql> SHOW COLUMNS FROM `test_table`;
+-------+--------------+------+-----+---------+----------------+
| Field | Type         | Null | Key | Default | Extra          |
+-------+--------------+------+-----+---------+----------------+
| id    | int          | NO   | PRI | NULL    | auto_increment |
| name  | varchar(255) | NO   |     | NULL    |                |
| ymd   | date         | NO   |     | NULL    |                |
+-------+--------------+------+-----+---------+----------------+

 

ソースコード

10日以内

SELECT * 
FROM `test_table` 
WHERE `ymd` >= DATE_ADD(NOW(), INTERVAL -10 DAY);

1ヶ月以内

SELECT * 
FROM `test_table` 
WHERE `ymd` >= DATE_ADD(NOW(), INTERVAL -1 MONTH);

1年以内

SELECT * 
FROM `test_table` 
WHERE `ymd` >= DATE_ADD(NOW(), INTERVAL -1 YEAR);

 - MySQL データベース

  関連記事

エックスサーバーでMySQLのサイズに注意

エックスサーバーで自動更新のログをMySQLに保存するようなシステムを動かしてい ...

MySQLでINSERT時にオートインクリメントではないカラムに連番を登録する方法

MySQLでINSERT時にオートインクリメントではないカラムに連番を登録したい ...

MySQLで1対多というテーブル構造でデータ結合と条件検索する方法

MySQLで飲食店舗テーブルと休業日テーブルがあり、1店舗に対して複数行の休業日 ...

MySQLでdatetime型にもインデックスを使用して高速化を図る方法

ログ関連のデータを格納するテーブルがあり、集計を行う際に非常に時間がかかった。レ ...

InnoDBのオートインクリメントで抜け番が発生する原因について

MySQLのInnoDBでIDというカラムにオートインクリメント設定していたが、 ...