ホームページ >データベース >mysql チュートリアル >MySQLで年齢差を整数として計算するにはどうすればよいですか?

MySQLで年齢差を整数として計算するにはどうすればよいですか?

DDD
DDDオリジナル
2024-10-29 18:10:50527ブラウズ

 How to Calculate Age Difference in Years as an Integer in MySQL?

MySQL で年齢差を整数として計算する

データベース内の人の年齢を決定する場合、年齢の計算を扱うときに若干の困難が生じます。 。 「id」列と「birth_date」列を持つ「student」テーブルについて考えてみましょう。

年齢を日数で計算するには、式 datediff(curdate(),birth_date) を使用できますが、これは浮動小数点値を返します。 。 365 で割ると浮動小数点値も得られます。

年を year(curdate())-year(birth_date) として計算すると、問題が発生します。たとえば、ある人が 1970 年 6 月に生まれ、現在の日付が 5 月である場合、式は 31 年ではなく 32 年を誤って返します。

整数年の差の代替解決策:

この問題に対処するには、次の SQL ステートメントを検討してください。

<code class="sql">SELECT TIMESTAMPDIFF(YEAR, date_of_birth, CURDATE()) AS difference FROM student</code>
この式は、'date_of_birth' と 'CURDATE()' の差を年単位で計算し、結果は整数値になります。

月と日の拡張子:

月単位の違いを計算するには、式の 'YEAR' を 'MONTH' に置き換えます:

<code class="sql">SELECT TIMESTAMPDIFF(MONTH, date_of_birth, CURDATE()) AS difference FROM student</code>
同様に、日数の違いについては、「YEAR」を「DAY」に置き換えます。

以上がMySQLで年齢差を整数として計算するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。