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

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

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

dateは、date型や日付に関する関数や処理についてのタグです

Oracle Database 11g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

Q&A

3回答

14205閲覧

Oracle SQL DATE型のソート順について

illbenoc

総合スコア8

date

dateは、date型や日付に関する関数や処理についてのタグです

Oracle Database 11g

Oracle DatabaseはRDBMSの商品です。具体的な発売商品として知られているのが、 Oracle9i、Oracle10g、Oracle 11gとOracle 12cです。

0グッド

0クリップ

投稿2017/10/30 10:54

###前提・実現したいこと
Oracle SQL 11gを使用しています。

USERS_TABLE
・ID VARCHAR2(20) //PRIMARY KEY
・BIRTHDAY DATE

###発生している問題・エラーメッセージ
このBIRTHDYキーを基準にしてソート(昇順)で取り出す時の動作の詳細がわかりません。
仮にそれぞれ

IDBIRTHDAY
190-12-03
215-01-03
395-08-13

というデータが格納されていた場合、
SELECT * FROM USERS_TABLE
ORDER BY BIRTHDAY ASC;
とした時、表示される結果は

IDBIRTHDAY
190-12-03
395-08-13
215-01-03

でした。

この場合は、90を1990、15を2015等と認識してソートしているのでしょうか。
※おそらく19XX年,20XX年というのも明確に内部で設定されていないのでしょうが、便宜上そう書かせてください。

日付を格納する段階で、上2桁を省略した場合、100年以内のデータと認識されて上記のようになるのでしょうか。

詳細な調べ方が思いつかないので質問させてください。
よろしくお願いします。

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

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

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

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

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

guest

回答3

0

OracleのDate型は「yyyy-mm-dd hh:mi:ss」という精度で情報を持っています。

「90-12-03」というのは表示形式が「yy-mm-dd」になっているだけであって、実際に保持している情報精度は別物です。

投稿2017/10/30 10:58

tkturbo

総合スコア5572

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

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

0

DATE型の有効範囲は Oracle Database に格納可能なデータ型 DATEをご覧ください。

sqlplusから

SQL

1ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY/MM/DD HH24:MI:SS' ; 2 3SELECT * FROM USERS_TABLE 4ORDER BY BIRTHDAY ;

で確認してください。

投稿2017/10/30 12:00

Orlofsky

総合スコア16417

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

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

0

日付を格納する段階で、上2桁を省略した場合、100年以内のデータと認識されて上記のようになるのでしょうか。

あくまで表示とは別物なので、2桁しか入力してないのであれば、そのとおりに格納されています。

SQL

1SELECT TO_CHAR(BIRTHDAY,'yyyy/mm/dd') FROM USERS_TABLE

のように、書式を指定して文字列として出力すれば、格納されている内容が確認できます。

投稿2017/10/30 11:36

編集2017/10/30 12:25
sazi

総合スコア25300

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問