MySQL で誕生日から年齢を計算する複数の方法

MySQL で誕生日から年齢を計算する複数の方法

以前はMySQLをあまり使用していなかったため、MySQLの機能にあまり詳しくありませんでした。この問題に遭遇したとき、Baiduで検索して、次の2つの方法を見つけました。この2つの方法は、Baiduのブログで1位にランクされていました。

方法1

DATE_FORMAT(FROM_DAYS(TO_DAYS(NOW())-TO_DAYS(誕生日))、'%Y')+0 AS 年齢を選択

著者はまた、方法 1 の欠陥を指摘しています。それは、日付が将来の日付である場合、結果が負の数ではなく 0 になるということです。ここでは 5 つの関数と 2 つの演算子が使用されています。

方法2

DATE_FORMAT(NOW(), '%Y') - DATE_FORMAT(誕生日, '%Y') - (DATE_FORMAT(NOW(), '00-%m-%d') < DATE_FORMAT(誕生日, '00-%m-%d')) を年齢として選択します

方法 2 は方法 1 の負の数の問題を解決しますが、より複雑で、ここでは 6 つの関数と 3 つの演算子が使用されています。

この投稿を読んだ後、私は混乱しました。なぜこんなに複雑なのでしょうか? 以前は Sql Server を使用するのは非常に簡単でした。シンプルで効率的な方法があるはずだと私は固く信じています。上記の方法を改良した方法がすぐに見つかりました。

改良方法1と方法2

year( from_days( datediff( now( ), birthdate)));を選択します。
YEAR(CURDATE())-YEAR(誕生日)-(RIGHT(CURDATE(),5)<RIGHT(誕生日,5));を選択します。

改良された方法 1 では、関数と演算子が 1 つ少なくなっています。日付が将来の場合、計算結果は依然として 0 になります。
改良された方法 2 には、依然として 6 つの関数と 3 つの演算子があり、よりシンプルに見えます。日付の右側の 5 桁を取得する場合、日付形式が「2013-01-01」の場合、結果は「01-01」となり、問題ありません。日付形式が「2013-1-1」の省略形式の場合、結果は「3-1-1」となり、エラーが発生します。

そこで、MYSQL ヘルプ ドキュメントの日付関数に基づいた 3 番目の方法を思いつきました。

方法3

FLOOR(DATEDIFF(CURDATE(), @誕生日)/365.2422) を選択

誕生日から現在の日付までの日数を、実際の 1 年間の日数 (365 日、5 時間、48 分、46 秒) で割り、切り上げます。これは、3 つの関数と 1 つの演算子だけで実行されます。

その後、私はすぐに海外のウェブサイトで4番目の方法を見つけました。

方法4

 TIMESTAMPDIFF(YEAR, @birthday, CURDATE()) を選択

この方法では、タスクを完了するために 2 つの関数のみを使用するため、これが最適な方法であるはずです。

上記の 4 つの方法をテストした後、現在の日付が「2017-1-13」で、誕生日が「2013-1-14」の場合、誕生日まであと 1 日、4 歳まであと 1 日ですが、結果は依然として 3 歳であり、妥当ではないようです。方法 3 を変更して切り捨てると、方法 5 になります。

方法5

SELECT ROUND(DATEDIFF(CURDATE(), @birthday)/365.2422)

この方法で計算された年齢は実際の年齢に最も近いですが、方法 4 が年齢の定義と最も一致している可能性があります。

要約する

上記は、MySQL で誕生日から年齢を計算する方法について紹介したものです。お役に立てば幸いです。ご質問がある場合は、メッセージを残してください。すぐに返信いたします。また、123WORDPRESS.COM ウェブサイトをサポートしてくださっている皆様にも感謝申し上げます。

以下もご興味があるかもしれません:
  • 生年月日で年齢を取得する PostgreSQL 操作
  • 生年月日を年齢に変換し、グループ化して人数を数えるMySQLの例
  • 日付関数で年齢を判断するための SQL サンプル コード

<<:  ZooKeeper をベースにした Hadoop 高可用性クラスタの構築のチュートリアル図

>>:  Ubuntu 18でターミナルを美しいコマンドラインプロンプトに変更する方法

推薦する

js オブザーバーモードの紹介と使用

目次定義2. 使用シナリオ3. 例を挙げる4. コーディング定義オブザーバー パターンは 1 対多の...

nginx.conf のルートディレクトリ設定の詳細な説明

nginx.conf を構成するときには常に何らかの問題が発生します。ここでは、よくある問題とその解...

JavaScript の toLocaleString() での時間フォーマットに関する新しいアイデア

目次1. 時刻表示に関する従来の考え方2. 時刻の書式設定 toLocaleString() Obj...

一意の注文番号を生成するためのMySQLの高同時実行方法

序文このブログ記事が公開された後、何人かの友人からSQL Serverバージョンがあるかどうか尋ねら...

MySQLのMVCCマルチバージョン同時実行制御の実装

1 MVCCとは何かMVCC の正式名称は、マルチバージョン同時実行制御です。データベースへの同時ア...

Centos7でglibcをアップグレードするとシステム異常(起動できない)になる場合の解決方法

目次問題の原因:解決:解決:私は Centos7 を使用しています (理論的にはこの方法は Cent...

MySQL テーブルにおける非主キー列オーバーフロー監視の詳細な説明

今日もまた罠に落ちてしまいました。 私は以前MySQLの主キーオーバーフローに遭遇したことがあり、そ...

Vue はボタンをクリックしてファイルをダウンロードする操作コードを実装します (バックエンド Java)

前回の記事では、ボタンをクリックしてファイルをダウンロードするVueの機能を紹介しました。今日は、ボ...

MySQL にテーブルデータを挿入するときに中国語の文字化けが発生する問題を解決する方法

1. 問題開発中に、他のデータベースから MySQL データベース テーブルにデータを挿入すると、次...

MySQL の同時実行性の問題と解決策の分析

目次1. 背景2. テーブルロックによるクエリの遅延3. オンラインでテーブル構造を変更するとどのよ...

Linux リモートログイン実装チュートリアル分析

Linux は一般的にサーバーとして使用され、サーバーは一般的にコンピュータルーム内に置かれます。L...

Nginx での Frp による https への強制リダイレクト設定の詳細な説明

自宅のルーターが300Mの帯域幅を80Mに強制的に減らしたため、3205Uソフトルーターを購入しまし...

Reactはページの透かし効果の全プロセスを実現します

目次序文1. 使用例2. 実施プロセス3. コンポーネントコード要約する序文1. cavans では...

DockerにMySQLをインストールする方法

最近 Django を導入しましたが、MySQL を手動でインストールしたくなかったので、Docke...

IEのクラッシュバグ

コードをコピーコードは次のとおりです。 <スタイル タイプ="text/css&qu...