MySQLにてSELECT時にdate型のカラムから和暦を計算し表示する方法
MySQLにdate型のカラムに誕生年月日が格納されており、そこから和暦を計算して取得したい。また、date型だと基本的には「YYYY-MM-DD」もしくは「YYYY/MM/DD」形式だと思うが、これを「〇〇Y年M月D日」に整形して表示したい。以下に対応方法をメモ。
テーブル構造とデータ内容
mysql> SHOW COLUMNS FROM `test_table`; +----------+--------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +----------+--------------+------+-----+---------+----------------+ | id | int | NO | PRI | NULL | auto_increment | | name | varchar(255) | NO | | NULL | | | birthday | date | NO | | NULL | | +----------+--------------+------+-----+---------+----------------+ mysql> SELECT * FROM `test_table`; +----+-----------+------------+ | id | name | birthday | +----+-----------+------------+ | 1 | 山田 | 2020-01-01 | | 2 | 鈴木 | 1990-05-05 | | 3 | 佐々木 | 1980-12-31 | +----+-----------+------------+
対応方法
SQL文
SELECT `birthday`, CASE WHEN `birthday` > '2019-04-30' THEN CONCAT('令和', YEAR(`birthday`) - 2018, date_format(`birthday`, '年%c月%e日')) WHEN `birthday` > '1989-01-07' THEN CONCAT('平成', YEAR(`birthday`) - 1988, date_format(`birthday`, '年%c月%e日')) WHEN `birthday` > '1926-12-24' THEN CONCAT('昭和', YEAR(`birthday`) - 1925, date_format(`birthday`, '年%c月%e日')) WHEN `birthday` > '1912-07-29' THEN CONCAT('大正', YEAR(`birthday`) - 1911, date_format(`birthday`, '年%c月%e日')) WHEN `birthday` > '1868-01-24' THEN CONCAT('明治', YEAR(`birthday`) - 1867, date_format(`birthday`, '年%c月%e日')) END AS `birthday_wareki` FROM `test_table`;
出力結果
+------------+-----------------------+ | birthday | birthday_wareki | +------------+-----------------------+ | 2020-01-01 | 令和2年1月1日 | | 1990-05-05 | 平成2年5月5日 | | 1980-12-31 | 昭和55年12月31日 | +------------+-----------------------+
参考サイト
関連記事
-
-
MySQLのクエリキャッシュの設定方法
MySQLでのクエリキャッシュ設定及び設定項目について以下にメモ。 ...
-
-
MySQLでストアドプロシージャ戻り値対応版であるストアドファンクションの設定と利用方法
先日MySQLのストアドプロシージャに関するメモを書いたが、今回はストアドファン ...
-
-
phpmyadminからプロセスの停止
重たいSQL文を叩いた際、どうにも処理できず メモリ使用率が100%から下がらな ...
-
-
MySQLにてdatetime型のカラムを整形し「年月日のみ形式」または「秒のみ省いた形式」で表示する方法
MySQLにてdatetime型のカラムに登録日時等を格納しており、管理画面側で ...
-
-
MySQLで同一サーバーの異なるDB内のテーブルをJOINする
同一のMySQLサーバーでdb1データベースのtable1テーブルと、db2デー ...