勉強したことのメモ

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

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

  MySQL データベース

MySQLにてdateもしくはdatetime型のデータを取り出して曜日もあわせて表示したいような場合、曜日部分のプログラムはPHPで対応していた。今更ながらだけどMySQLで対応できるんじゃないのかと思って調べたところ簡単に対応できた。以下に対応方法をメモ。

 

テーブル構造とデータ内容

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

mysql> SELECT * FROM `test_table`;
+----+------------+
| id | ymd        |
+----+------------+
|  1 | 2024-01-01 |
|  2 | 2024-01-02 |
|  3 | 2024-01-03 |
|  4 | 2024-01-04 |
|  5 | 2024-01-05 |
|  6 | 2024-01-06 |
|  7 | 2024-01-08 |
+----+------------+

 

対応方法

SQL文

SELECT `ymd`,
    CASE DAYOFWEEK(`ymd`) 
        WHEN 1 THEN '日' 
        WHEN 2 THEN '月' 
        WHEN 3 THEN '火' 
        WHEN 4 THEN '水' 
        WHEN 5 THEN '木' 
        WHEN 6 THEN '金' 
        WHEN 7 THEN '土' 
    END AS week 
FROM `test_table`;

出力結果

+------------+------+
| ymd        | week |
+------------+------+
| 2024-01-01 | 月   |
| 2024-01-02 | 火   |
| 2024-01-03 | 水   |
| 2024-01-04 | 木   |
| 2024-01-05 | 金   |
| 2024-01-06 | 土   |
| 2024-01-08 | 月   |
+------------+------+

 

リファレンス

DAYOFWEEK

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

 - MySQL データベース

  関連記事

MySQLで特定のテーブルにパーティショニング設定し高速化を図る方法

以前に他社が設計されたログ系のテーブルを拝見した際にパーティショニング設定が行わ ...

MySQLでIPを整数値としてカラムに格納する

MySQLでIPを整数値としてカラムに格納しているケースがあった。今までIPが必 ...

PHP / MySQLで2038年問題の対策

先日打ち合わせの際に「タイムスタンプを使ってユニークキーに云々~~」といったよう ...

MySQLでphpMyAdminやAdminer上だけ文字化けする場合の対応方法

レンタルサーバーのプログラムでWebページ上では文字化けしていないのに、phpM ...

PHPからMySQLにシリアライズしたデータを格納

アンケートフォームみたいなのがあって、 今後も定期開催し、尚且つ質問内容は増減す ...