勉強したことのメモ

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 データベース

  関連記事

WordPressサイトのロードアベレージが高い際の対応方法
WordPressサイトのロードアベレージが高い際の対応方法

あるWordPressサイトのロードアベレージが先月ぐらいまでは通常0.5前後で ...

MySQLで指定したカラムの中央値を抽出する方法
MySQLで指定したカラムの中央値を抽出する方法

MySQLで指定したカラムの中央値を抽出したいというケースがあった。MariaD ...

PLESK利用時にMySQLでrootのパスワードが分からない場合の対応方法
PLESK利用時にMySQLでrootのパスワードが分からない場合の対応方法

pleskで管理しているサーバがあり、mysqlのrootのパスワードが分からな ...

MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法
MySQLのバイナリログ(/var/lib/mysql/binlog)を適切に削除する方法

レンタルしているVPS内のファイルを整理していると「/var/lib/mysql ...

MySQLで一連の処理を関数のように実行できるストアドプロシージャの設定と利用方法
MySQLで一連の処理を関数のように実行できるストアドプロシージャの設定と利用方法

MySQL関連のサイトを見ていた際にストアドプロシージャが云々というページがあっ ...