文字列を日付に変換するところで、「ParseException: Unparseable date: "2013/08/06"
at java.text.DateFormat.parse(DateFormat.java:335) 」とエラー表示されました。
実際のコーディングは
Date sgndate = new Date();
if(!StringUtil.isNull(rs.getString("sgnymd"))){
String lstdaysgn = rs.getString("sgnymd");
lstdaysgn = lstdaysgn.substring(0,4) + "/" + lstdaysgn.substring(5,7) + "/" +
lstdaysgn.substring(8,10);
sgndate = DateFormat.getDateInstance().parse(lstdaysgn); ・・・・・・・・・ここでエラー発生
}
どこが悪いのか解りません。
よろしくご教授ください。
No.2ベストアンサー
- 回答日時:
どこが悪いって
DateFormat.getDateInstance().parse(lstdaysgn);
が悪い。実際エラーはそこで起こってるんだし。で、そこの部分について手直しよりも一つ提案があるので聞いてみてくれたまい。
仮にrsがデータベースからSELECT文でデータを取ってきた時のレコードセットであり、かつrs.getString("sgnymd")がyyyyMMdd形式の(スラッシュが付かない)8桁の数字文字列であり、かつ単純にその日付でDate型にしたいだけなのであればこうしたらいいんじゃないか。
Date sgndate = null; // new Date()しない。もちろん後続のルーチンでnullチェックは要るようになる。
if(!StringUtil.isNull(rs.getString("sgnymd"))){
String lstdaysgn = rs.getString("sgnymd");
// ↓これもしない。
// lstdaysgn = lstdaysgn.substring(0,4) + "/" + lstdaysgn.substring(5,7) + "/" +
// lstdaysgn.substring(8,10);
sgndate = new SimpleDateFormat("yyyyMMdd").parse(lstdaysgn); // スラッシュつけずに8桁のyyyyMMddでそのままDateにする。
}
以上の手直しにより、このルーチンを通る際にDate 1つとString 7つ、インスタンスの生成を回避する事ができる。これがループで処理されるならなおさら。
仮に、「new SimpleDateFormat("yyyyMMdd")だとパースのたびにSimpleDateFormatのインスタンスが作られちゃうジャン!」と思うならルーチン化していいと思うけど、その場合はスレッドセーフなルーチンにしないといけないのでそこらへん注意の事。
この回答への補足
実は、ParseExceptionが必ず起きるのではなく、2年ほど前から使っていて初めて起きました。
再現テストでも起きないので、質問させていただきました。
なぜ、いままで正常に処理されていたのでしょうか。お分かりになりましたら教えてください。
よろしくお願いします。
No.3
- 回答日時:
> なぜ、いままで正常に処理されていたのでしょうか。
お分かりになりましたら教えてください。分からん(笑)。
冗談はともかくとして、本当に僕には分からない。なぜかというとそのプログラムの前後、実行環境(OS、JavaVMの実装、コンテナ、ブートストラップ)が分からないからだ。
あなたもエラーになったりならなかったりすると言っているように、DateFormat.getInstance()で取得されるDateFormatインスタンスは状況や環境に大きく依存する。Windows 7(32bit)+Oracle JDK 1.7.0_25(32bit)で開発中はうまく動くのに、本番環境のLinux 2.6.32(64bit)+OpenJDK 1.7.0_25(64bit)だと動かないとかも当たり前にある。
今取得されたDateFormatインスタンスがどんな書式を受け付けるかを確認するにはformatでDateからStringにしてみればいい。それが
"09/10/13 19:19:25"
になっているかも知れないし、
"Tue Nov 10 19:19:25 JST 2013"
になっているかも知れない。この辺はリージョン(日本とか)、言語(日本語とか)、バリアント(日本には関係ない)が関わってくる。ja_JPというのは、日本語(ja=Japanese)、日本(JP=Japan)、バリアントなしというJavaのローカライゼーション識別子になる。日本では日本語以外の公用語はないし、日本語は日本以外では公用語にならないのでjaは普通JPと対だけど、英語(en)の場合はアメリカ英語(en_US)とイギリス英語(en_GB)があったり、カナダにはフランス語(fr_CA)と英語(en_CA)があったり、まぁそんなこんなを全部含めた「カルチャー」によって日付をあらわす文字列が変わるために、ロケールに引っ張られるDateFormat.getInstance().parse()は状況が変わるとエラーになったりならなかったりなんだ。
まぁ、結局何の回答にもなってないけど、とにかくDateFormatじゃなくって(特にデータベースにyyyyMMdd形式のvarchar(8)で保存している時など)形式を厳密に指定できるSimpleDateFormatを使う方が部品化も簡単になるし、トラブルも少なくなるわよという事。プログラマーならこんなところじゃなくってビジネスロジックの組み立てに時間を費やしたいわよね。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- その他(コンピューター・テクノロジー) 【Tableau Desktop】文字列から8桁の数字を日付型(yyyyMMdd)として取得 1 2023/07/31 10:17
- JavaScript 1日1回引けるJavaScriptおみくじについて 1 2022/12/12 22:28
- JavaScript プラグイン無しでContactform7にdatepickerを実装 3 2022/10/25 02:18
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- Visual Basic(VBA) VBAでファイルを開くプログラムがエラーです 2 2023/02/21 16:56
- C言語・C++・C# C#テキストボックスの文字を配列にいれてその後表示する 4 2022/07/17 04:47
- Excel(エクセル) Excel2019、2021の日付、曜日の表示について 2 2022/11/29 15:01
- JavaScript 入力フォームの javascript で メールアドレスの正規チェックをを行い、ボタンをクリックして 2 2022/04/27 16:06
- JavaScript フォームが空欄の時にフォームの外をクリックすると、エラーが出るコードを調べています。 1 2023/06/25 11:51
このQ&Aを見た人はこんなQ&Aも見ています
-
プロが教える店舗&オフィスのセキュリティ対策術
中・小規模の店舗やオフィスのセキュリティセキュリティ対策について、プロにどう対策すべきか 何を注意すべきかを教えていただきました!
-
IOException ってどういうときに起こるのでしょうか?
Java
-
【C#/Java?】try-catchでcatchせずにfinallyは一般的?
その他(プログラミング・Web制作)
-
java junit list同士の比較方法
Java
-
-
4
int型のゼロ埋め
Java
-
5
[JAVA]try 内の変数を外で!?
Java
-
6
Eclipse「リフレッシュ」と「クリーン」の違い
Java
-
7
java-別クラスの変数の使い方を教えてください
Java
-
8
String型の日付(2005/11/25)の比較
Java
-
9
yyyymmddからyyyy/mm/ddへの変換
Java
-
10
string formatについて
Java
-
11
オブジェクトの中のプロパティを認識できません
Java
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
変数名の付け方
-
private static という変数の修飾
-
インスタンス参照でアクセスで...
-
C# インスタンスの破棄
-
複数の変数を宣言する時、同時...
-
C#において、同じインスタンス...
-
VB.NET getとsetの概念がわかり...
-
他のファイルの変数参照
-
生成したインスタンスを削除す...
-
非staticフィールドを参照でき...
-
VB.netで標準モジュールからフ...
-
変数の参照でエラーが出てしま...
-
ファイル読み込み/書き込み速度...
-
VB.NET Newしたものを変数に代...
-
フィールドでのnewとコンストラ...
-
フォームの存在をチェックする方法
-
整数の引数に列挙を使ったとき
-
インスタンスを同じ名前で作成...
-
文字列を日付に変換でParseExce...
-
SerialPort処理でInvokeメソッ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
変数名の付け方
-
インスタンス参照でアクセスで...
-
複数の変数を宣言する時、同時...
-
private static という変数の修飾
-
VB.NET getとsetの概念がわかり...
-
C#において、同じインスタンス...
-
生成したインスタンスを削除す...
-
C# インスタンスの破棄
-
newしないインスタンス?実体化...
-
SQLを連続発行する時の正しい(?...
-
「インスタンス」の意味をわか...
-
文字列を日付に変換でParseExce...
-
変数の参照でエラーが出てしま...
-
フォームの存在をチェックする方法
-
javaのクラスの作り方、エラー...
-
オブジェクト参照がオブジェク...
-
String a = "a"; と String b =...
-
エクセル(複数インスタンス)...
-
C#「オブジェクト参照が必要で...
-
他のファイルの変数参照
おすすめ情報