ホームページ >データベース >mysql チュートリアル >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 サイトの他の関連記事を参照してください。