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

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

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

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

Q&A

解決済

2回答

13133閲覧

DATE型のデータをTO_CHARで文字型に変換する際に、年月日が逆転してしまう。

退会済みユーザー

退会済みユーザー

総合スコア0

Oracle

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

0グッド

0クリップ

投稿2017/09/14 10:13

DATE型のデータをTO_CHARで日付に変換すると、日付が逆転してしまうという現象に見舞われました。

PL/SQL

1HOGE DATE: 2HAGE CHAR; 3 4HOGE := '2017/09/01 00:00:00'; 5HAGE := TO_CHAR(HOGE,'YYYY/MM/DD HH24:MI:SS)

と、このように、日付を文字に変換すると、HAGEに入る値は、

'0001/09/17 00:00:00'

となってしまうのです。

HAGE := TO_CHAR(HOGE,'DD/MM/YYYY HH24:MI:SS)

とすると、

'2017/09/01 00:00:00'

と、きちんと入ります。

このような現象になってしまうのですが、理由が全くわからなくて困惑しています。
同じような現象が起こった方はいらっしゃいまあうでしょうか?

何かしらヒントとなるような事でもいいので、ご助言を頂けましたら幸甚です。

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

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

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

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

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

guest

回答2

0

ベストアンサー

HOGEに日付書式の文字列で代入してるからじゃないですかね。

HOGE := TO_DATE('2017/09/01 00:00:00', 'YYYY/MM/DD HH24:MI:SS'); HAGE := TO_CHAR(HOGE,'YYYY/MM/DD HH24:MI:SS');

としたら、どうなります?

※HAGEはダメでしょ(笑)

投稿2017/09/14 10:31

sazi

総合スコア25195

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

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

退会済みユーザー

退会済みユーザー

2017/09/16 04:48

sazi様 そのあたりは何度も試したのですが、 結果としましては、 '0001/09/17 00:00:00'となりました。
sazi

2017/09/16 10:51

では、 select sysdate from dual とすると、どのように表示されますか。 そもそもですが、HAGEの内容の確認はどのようにされていますか。 HAGE := TO_CHAR(HOGE,'DD/MM/YYYY HH24:MI:SS) で、文字列として代入しているのに書式が変わるのは見たことがありません。
退会済みユーザー

退会済みユーザー

2017/09/19 23:08

sazi様 select sysdate from dual の結果は、'2017-09-19'になります。
退会済みユーザー

退会済みユーザー

2017/09/19 23:11

HAGEの確認は、SQL Developerで、DBMS_OUTPUT.LINEを使っています。
sazi

2017/09/20 01:00 編集

断片的な情報ではこれ以上は難しそうです。 SQL Developerであればデバッグできますよね。 変数の中身はどうなっているのか確認していますか? それでも解決しないなら、全体的に具体的なコードおよび実行環境を提示して貰えますか。
退会済みユーザー

退会済みユーザー

2017/10/07 02:53

sazi様 いろいろとありがとうございます。 結論から申し上げますと、解決できました。 解決方法は、DATE型の引数の値をそのままTI_CHAR(HOGE,'YYYY/MM/DD')と渡すとYYとDDが逆転してしまっていたのですが、引数でわたってきたHOGEを一旦、一旦VAERVHAR2型の変数にTO_CHRA(HOGE.'YYYY/MM/DD')に格納して、それを引数で渡せば逆転しなくなりました。 (何言っているのかわかなければすいません。私もなぜこんな事で逆転しなくなったのか理由が説明できません。) パッケージソフトを使っているので、パッケージソフトのバグかもしれません。
guest

0

質問とちょっとずれるけど、

暗黙の型変換に頼るとパフォーマンスの低下や誤動作の恐れがあります。
十分なデータ量がない開発環境では問題がなくても何千万件、何億件もデータがあるかもしれない本番環境では暗黙の型変換によるTABLE ACCESS FULLが多発したらたまりません。

データが多くなったら直せば良いって人がいますが、その時バグ対応としてあなたは無償でプログラムを直せますか?それとも他の人が直したとして、その費用をあなたが払えますか? て諭さないといけない場面が何度もあります。

わたしはOracle Client が使える時は{$ORACLE_HOME]/sqlplus/admin/glogin.sql の最後に
ALTER SESSION SET NLS_DATE_FORMAT = 'YYYY/MM/DD HH24:MI:SS' ;
ALTER SESSION SET NLS_TIMESTAMP_FORMAT = 'YYYY/MM/DD HH24:MI:SSXFF' ;
ALTER SESSION SET NLS_TIMESTAMP_TZ_FORMAT = 'YYYY/MM/DD HH24:MI:SSXFF TZR' ;
を追加しています。

投稿2017/09/14 22:29

Orlofsky

総合スコア16415

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

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

退会済みユーザー

退会済みユーザー

2017/09/16 04:46

Orlofsky様 なるほど。。。 勉強になります。 ありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問