MySQL での整数としての年の差の計算
データベース内の人の年齢を決定する場合、年齢の計算を扱うときに少し問題が発生します。 。列「id」と「birth_date」を持つ「student」テーブルについて考えてみましょう。
年齢を日数で計算するには、式 datediff(curdate(),birth_date) を使用できますが、これは浮動小数点値を返します。 。 365 で割ると浮動小数点値も得られます。
年を year(curdate())-year(birth_date) として計算することでも問題が発生します。たとえば、ある人が 1970 年 6 月に生まれ、現在の日付が 5 月である場合、式は 31 年ではなく 32 年を誤って返します。
整数年の差の代替解決策:
この問題に対処するには、次の SQL ステートメントを検討してください:
SELECT TIMESTAMPDIFF(YEAR, date_of_birth, CURDATE()) AS difference FROM student
この式は、'date_of_birth' と 'CURDATE()' の差を年単位で計算し、整数値が得られます。
月と日の延長:
差額を計算するには月の場合、式内の 'YEAR' を 'MONTH' に置き換えます:
SELECT TIMESTAMPDIFF(MONTH, date_of_birth, CURDATE()) AS difference FROM student
同様に、差については日数では、'YEAR' を 'DAY' に置き換えます:
SELECT TIMESTAMPDIFF(DAY, date_of_birth, CURDATE()) AS difference FROM student
免責事項: 提供されるすべてのリソースの一部はインターネットからのものです。お客様の著作権またはその他の権利および利益の侵害がある場合は、詳細な理由を説明し、著作権または権利および利益の証拠を提出して、電子メール [email protected] に送信してください。 できるだけ早く対応させていただきます。
Copyright© 2022 湘ICP备2022001581号-3