こんにちは。
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.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で質問しましょう!
似たような質問が見つかりました
- PHP プログラムコードを入力する場合改行してもいいですか? 2 2022/10/02 16:05
- Excel(エクセル) EXCELの「接続」のSQLのコマンド文字列にて、セルから任意の数値を利用したい 2 2023/03/09 16:43
- Visual Basic(VBA) データベースから絞り込んでデータを読み込み 1 2023/02/21 19:51
- PHP ここでの ②if($su_d<>"")の比較演算子 を使う理由は 1 2022/03/26 02:33
- MySQL #1062 - '0' は索引 'PRIMARY' で重複しています。とでています。 1 2023/01/01 06:13
- Oracle SQLの書き方について 1 2023/04/13 09:54
- SQL Server AccessのInsertクエリのあとつづけてDeleteクエリを行いたいがSQLでどう書いたらいい 3 2023/05/27 14:12
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- Visual Basic(VBA) access count数を変数に格納 2 2022/03/30 19:21
- Excel(エクセル) PHPプログラムをエクセルに張り付けると検索ボックスがでてくる! 3 2022/05/08 07:10
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
Eclipseの対応する括弧の強調表...
-
VisualBasic6.0のFormat関数で...
-
エクセルのVBAで日付を検索し転...
-
DataGridViewでyyyy/MM/dd
-
VB6.0 のformat関数について
-
3人のじゃんけんのプログラム
-
週間カレンダー vbscript
-
指定した日付が、その月の第何...
-
【Excel VBA】条件に合った行の...
-
Laravelクエリビルダにてウィン...
-
今日より前の書き方 マクロ
-
htmlで日付表示。三日後の日付...
-
VB.NET 日付設定
-
該当の日付以外を消去するプロ...
-
SqlCommandBuilder 使用時のサ...
-
excelのVBAについて、以下のコ...
-
ユーザーフォームのラベルに日...
-
完全一致の検索
-
C++で日付判定を行いたい!!
-
JSPからYYYYMMDDで日付入力する
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
Eclipseの対応する括弧の強調表...
-
人をはめた人は 自分に返ってく...
-
DataGridViewでyyyy/MM/dd
-
エクセルのVBAで日付を検索し転...
-
ユーザーフォームのラベルに日...
-
VisualBasic6.0のFormat関数で...
-
コンボボックスに日付を表示する
-
テキストボックスにカレンダー...
-
1本あたり○円と表示する時どの...
-
指定した日付が、その月の第何...
-
VBAで当月の1日を表示するには...
-
VBA 日付・時刻の判別 時刻を認...
-
今日より前の書き方 マクロ
-
システム日付とは?
-
テキストボックスに今日の日付...
-
DateTimePickerを西暦表示にす...
-
JSPからYYYYMMDDで日付入力する
-
C++で日付判定を行いたい!!
-
ExcelVBAでSQLサーバの日付時刻...
-
【Excel VBA】条件に合った行の...
おすすめ情報






