skillup

技術ブログ

Database Java

日付がらみの処理に関して(MySQL&Java)

投稿日:

MySQL触りだして3年ぐらいたつんですがいまだに整理できないことが多いです。(特に日付がらみ)

ちょっとJavaのネタと合わせて整理しておこうかなーと思います。

MySQLの日付に関して

まずは型に関して日付は下記のようなものがあります。

date

YYYYーMMーDD型

日付に関して時分秒が取り扱えません。

time

HH:MM:SS型

いわゆる日付などの時間ではなく、経過時間などの型を知りたいときに有効

datetime

YYYYーMMーDD HH:MM:SS型

データ作成日、更新日などによく使われるデータの型

timestamp

YYYYーMMーDD HH:MM:SS型

datetimeと同様。

datetimeとtimestampの違い

  • datetimeは日付の範囲が ‘1000-01-01 00:00:00’ から ‘9999-12-31 23:59:59’なのに対してtimestampは’1970-01-01 00:00:01’ から ‘2037-12-31 23:59:59’。
  • バイト数がtimestampは4バイトに対してdatetimeは8バイト

他にもいろいろと違いはありますが、現状だとtimestampを使ったほうがメモリの省略になりそう。

参考リンク

http://www.dbonline.jp/mysql/type/index4.html

http://tech-blog.tsukaby.com/archives/179

出力での整形

通常yyyyMMdd hhmmssなど日付型のデータで格納されているものを整形しyyyyMMなどで出力したり、検索条件などで使いたいとき。

下記のようにすれば表示できます。

表記方法は下記リンクを参考に

http://pentan.info/sql/mysql/func/date_format.html

DEFAULTの型

insertしたときのdefault値の決定ですが、CURRENT TIMESTAMPを指定してあげるとその時の時間がぴったり入ります。

が、これは1テーブルにつき1つのカラムにしか使えません。2つ以上に使用した場合、2つ目以降が自動的に”0000-00-00 00:00:00″になります。

その場合、MySQL側で普通にNOW()などと入れるしかありません。

ちなみにyyyyMMの日付を格納する場合どうしたらいいかを考えていましたがintにしてそのまま入れるという意見がありました。

確かに不細工ですが大小関係などがわかるのと日付の加算などはプログラム側で行えばよいということでしょう。

参考リンク

http://qa.atmarkit.co.jp/q/2190

Javaでの日付処理

日付に関しては今まで標準のAPIを使っていましたが、joda-timeというライブラリが有名のようですね。

ここら辺は整理しておきたいところです。

pomでのインストール

まだ全然使えていないので折をみつけて使用法を確認しておきたいところです。

参考リンク

 

-Database, Java
-,

執筆者:


comment

メールアドレスが公開されることはありません。 * が付いている欄は必須項目です

関連記事

no image

新アプリの本番環境デプロイについて

新しく作ったWEBアプリを本番配置しようとしたんですが、何度もやっているはずの処理がいざやろうとするといろいろと手間取ってしまい、1時間近くかかりました。 容量悪いなーと思いつつ、こういった行為はなる …

no image

Optionalについて その2

JavaEEブログなはずなのに11月はcakeのことばかり書いていて、Javaのことすら書いていないですね(汗) 今日はOptionalについて書きます。 いまいち使い方がわからなかったんですが、自分 …

no image

GlassFishでDB接続

一般的にWEB系の言語で、DBを使う場合、WEBサーバーとDBサーバーは単独に動くことが一般的です。 JavaEEではアプリケーションサーバーとしてGlassFishを使いますが、先日、GlassFi …

no image

データベース設計のアンチパターン 重すぎるOLTP+Date型不統一+データ量想定が甘い

Contents1 重すぎるOLTP1.1 デメリット1.2 対策2 DATE型の型の不統一2.1 デメリット2.2 対策3 データ量の想定が甘い3.1 デメリット3.2 対策 重すぎるOLTP ※O …

no image

MySQLでの日付関数

MySQLでSUMやCOUNTなんかはよく使うと思うのですが、日付の関数なんかもかなり使います。 今回は、日付の日数をとりたいときの関数を紹介。 例えばあるカラムにある日付が入力されており、現在との日 …