

こんにちは。
JSPからサーブレット・Beanを使うプログラムを作っております。
調べてみたのですがわからなくなってきてしまいました。
ぜひご教授ください。
JSPから日付を入力し、DBに日付データを挿入します。
今はBeanから下のようなSQL文で、JSP画面からはフォームに「2008-08-20」と入力して値を挿入しています。
sql = insert into テーブル名 values('?')
できればこのフォームに「20080820」と入力させたいと思っています。
そのためにはBeanでSQL文を発行する際に日付を分けて、「2008」+「-」+「08」+「-」+「20」のように間に「-(ハイフン)」を入れてやればいいのはわかるのですが、そのためにはどのようにすればよいか教えてください。
「20080820」を分けて、sql1・sql2・…に入れ、それを実際のSQL文発行の際にsql1+"-"+sql2+…とやるのでしょうか?
よろしくお願いいたします。
No.3ベストアンサー
- 回答日時:
日付の変換にはSimpleDateFormatが便利です。
------------------------------------------------------------
String str1 = "20080820";
String str2;
// SimpleDateFormatオブジェクトを生成
SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyyMMdd");
// 年月日解析
Date date = simpleDateFormat.parse(str);
if(date != null) {
// フォーマットパターン変更
simpleDateFormat.applyPattern("yyyy-MM-dd");
// yyyy-MM-dd文字列でフォーマット
str2 = simpleDateFormat.format(date);
}
else {
// フォーマット失敗処理
}
------------------------------------------------------------
また、日付フォーマット関数が用意されているDBMSが殆どなので
そちらを使うのも宜しいと思います。
回答ありがとうございました!
SimpleDataFormatでこんな簡単にフォーマットが変えられるとは。
更に初歩的な質問で申し訳ないのですが、フォームから入力した日付
(20080820)を「?」で受け取りそれを変換するということですよね。
そのあとにPreparedStatementに値をセットしていざsql実行だと思うのですが、
>String str1 = "20080820";
の"20080820"の部分は「?」からどう受けたらよいのでしょうか?
すみません、よろしくお願いいたします。
==============================================
sql = "insert into テーブル名 values (?)";
~(コネクション取得)~
**この部分で変換作業**
stmt = dbConn.preparedStatement(sql);
stmt.setString(1,変換済の日付);
stmt.executeUpdate(); //実行 ……
=============================================
No.4
- 回答日時:
今回の場合、str1の文字列日付を変換し、
str2に変換後の文字列日付が格納されるので。
stmt.setString(1,str2);
で大丈夫だと思います。
No.1
- 回答日時:
java.lang.Stringのsubstringを使えばできます。
-----
String s1 = "20080820":
String s2 = s1.substring(0,4) + "-" + s1.substring(5,6) + s1.substring(7,8);
-----
細かい使い方はAPIドキュメントを参照してください。
実際にはいきなりsubstringをやると、文字数が足りなかったりすれば
例外(java.lang.StringIndexOutOfBoundsException)が発行されてしまいますし、
文字数が足りていても日付として正しいかどうかわかりませんから、
入力チェックを事前に行う必要があるでしょう。
参考URL:http://java.sun.com/javase/ja/6/docs/ja/api/inde …
回答ありがとうございました!
私が初め考えていたのはこのタイプだったようです。
中途半端な知識でお恥ずかしい限りです。
入力チェックも私にとっては難関なのですが、色々試してみます。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのVBAで日付を検索し転...
-
JSPからYYYYMMDDで日付入力する
-
VB6.0 のformat関数について
-
Eclipseの対応する括弧の強調表...
-
ExcelVBAでSQLサーバの日付時刻...
-
【VBA】土日をスキップして日付...
-
【Excel VBA】条件に合った行の...
-
VBAのapplication.ontime メソ...
-
コンボボックスに日付を表示する
-
VBA 日付、未来の日付はエラー...
-
VBAで当月の1日を表示するには...
-
システム日付とは?
-
1本あたり○円と表示する時どの...
-
ユーザーフォームのラベルに日...
-
指定した日付が、その月の第何...
-
VisualBasic6.0のFormat関数で...
-
エクセルvba. PDF保存 フォルダ...
-
DateTimePickerを西暦表示にす...
-
【Androidスマホ】の本体上部に...
-
iPhoneのプッシュ通知の過去履...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Eclipseの対応する括弧の強調表...
-
DataGridViewでyyyy/MM/dd
-
ユーザーフォームのラベルに日...
-
エクセルのVBAで日付を検索し転...
-
VisualBasic6.0のFormat関数で...
-
VB6.0 のformat関数について
-
JSPからYYYYMMDDで日付入力する
-
「eclipseで作るカレンダー(ス...
-
システム日付とは?
-
該当の日付以外を消去するプロ...
-
今日より前の書き方 マクロ
-
【VBA】土日をスキップして日付...
-
1本あたり○円と表示する時どの...
-
完全一致の検索
-
指定した日付が、その月の第何...
-
3人のじゃんけんのプログラム
-
コンボボックスに日付を表示する
-
excelのVBAについて、以下のコ...
-
VBA 表作成 続続
-
【Excel VBA】条件に合った行の...
おすすめ情報