MySQL 4.1.xで

誕生日(date型)から年齢の計算をしたいと思います。

YEAR(CURDATE()) - YEAR(`birthday`)) - (RIGHT(CURDATE(), 5) < RIGHT(`birthday`, 5)) AS `age`

とすればでるのが分かったのですが、
1970年より前は、UNIXTIMESTAMPの関係か、正常に出てくれません。

MySQLだけで1970年より前に生まれた人も含めて年齢を出すにはどうすれば良いでしょうか?

回答の条件
  • 1人2回まで
  • 登録:2009/02/17 21:50:54
  • 終了:2009/02/20 20:03:55

ベストアンサー

id:pahoo No.1

pahoo回答回数5960ベストアンサー獲得回数6332009/02/17 22:21:00

ポイント60pt

手元の MySQL 4.0.26 で実行してみましたが、ご質問の SQL は 1969年以前でも正常に動作します。


MySQL 4.1 リファレンスマニュアル」によれば、DATE型は

サポートしている範囲は、'1000-01-01' ~ '9999-12-31' です。 

と記されていますので、UNIX TIMESTUMP は関係ないはずです。


もし、DATE型ではなく TIMSTAMP 型であるとすると、「MySQL 4.1 より前のバージョンにおける TIMESTAMP」に記されているとおり、

TIMESTAMP 値は 1970 年の始まりから 2037 年の一定の時点までを範囲とし、

となり、1970年の壁があります。

まずは、TIMESTAMP 型になっていないかどうか、ご確認ください。

id:caster777

なるほど、元の型で動作が違うのですね。

確認します。


----------


そのとおり、timestamp型になっていました。

ありがとうございます。

2009/02/20 20:03:51

コメントはまだありません

この質問への反応(ブックマークコメント)

「あの人に答えてほしい」「この質問はあの人が答えられそう」というときに、回答リクエストを送ってみてましょう。

これ以上回答リクエストを送信することはできません。制限について

絞り込み :
はてなココの「ともだち」を表示します。
回答リクエストを送信したユーザーはいません