質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

Q&A

解決済

2回答

6292閲覧

Oracleで時刻のみを扱いたい場合のカラムのデータタイプは何を使っていますか?

退会済みユーザー

退会済みユーザー

総合スコア0

Oracle

Oracleは、米オラクルが取り扱うリレーショナルデータベース管理システムです。メインフレームからPCまで、多様なプラットフォームに対応しています。

0グッド

0クリップ

投稿2017/08/16 23:20

Oracleの列の定義についてご質問させて下さい。

単に時刻のみを扱いたい場合は、カラムのデータタイプは何をつかっていますか?

Dateですか?

Numberですか?

Vercharですか?

Dateで時刻を扱うと、日付部を暗黙の了解で1900/1/1をセットしたりなど、いまいちスマートじゃないなぁと。。。

でも、NumberやVercharだと、データが時刻フォーマットかどうかのチェックが大変になるし。。。など。

そもそも、Oracleは、どうして、日付のみ、時刻のみのデータタイプが無いのでしょう?

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

自分が、どうしても時刻のみで扱う必要があったら、数値型か文字型で書式をHH24MISSの書式で格納しますね。

で、出し入れする場合は日付型との変換経由で行う。

書式のチェックは日付型への型変換でのエラーを拾うだけでいいし、日付型を採用したとしてもやることはほぼ同じですしね。

文字型にするか数値型にするかについては、目的次第ですね。

日付型に変換するには、文字型の方が数値型よりひと手間少なくて済みますけど、容量を考慮しないと行けない場合は数値型ということになりますし。

時刻のみで扱いたい場合で考えられることとしては、記録ではなく時間帯などのマスター的な使い方をするものしか思いつかないので、それだったら数値型を使いそうです。

投稿2017/08/17 01:49

sazi

総合スコア25193

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/08/17 13:08

sazi様 ご回答ありがとうございます。 うーん、なるほど。 時と場合によりけりですね。。。^^;
guest

0

ベストアンサー

Oracleでやるなら、DATE型ですかねぇ。
NUMBERVARCHAR2だと、おっしゃるようにバリデーションの手間が必要になりますが、DATEなら日付部分を無視するだけですみますし。

ただ、時刻をどう扱いたいか、の要件次第かとは思います。
たとえば、営業時間の開始と終了を保持し、現在日時が営業時間内なのかどうか判定したいのか、単に何らかの表示項目として使うだけなのか、あるいは何らかの計算が必要なのか(何時何分から何時間何分後は何時何分後か、とか)、などなど。
要件を明確にして適切な型を選びましょう、というつまらない回答になってしまいますね。

投稿2017/08/17 00:13

alg

総合スコア2019

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

退会済みユーザー

退会済みユーザー

2017/08/17 13:07

alg様 あぁ、なるほど。 やっぱりDate型ですね。。。 Oracleって時刻型って出来ないんですかね。。。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問