勉強したことのメモ

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で全角半角を区別せずに検索する方法(collate utf8_unicode_ci)

あるシステムでMySQLの検索時に「WHERE test_column coll ...

MySQLで検索した件数の取得

ページングとかで必要になる総件数について、 いつもググってしまっていたのでメモ。 ...

MySQLで経度緯度から半径○Kmのデータを抽出する方法

経度と緯度をtext型として格納しているMySQLのテーブルがあり、指定した経度 ...

MySQLにてdate型のカラムから曜日を計算し表示する方法

MySQLにてdateもしくはdatetime型のデータを取り出して曜日もあわせ ...

phpMyAdminでのエクスポート/インポート

DBのバックアップを取る際にエクスポート/インポートを行うが、 データ件数が多い ...