以下の様な開発環境でシステムを構築しています。
OS:windowsXP
DB:Microsoft Access 2002
j2sdk:1.4.2_05
Tomcat:4.1.30
Web上で登録画面を表示、登録されたデータをサーブレット経由でDBに登録しようとしたところ、「パラメータが少なすぎます」というメッセージが出て登録できませんでした。
DBおよびSQL構文のエリア名の記入ミスも調べましたが問題ない模様です。
AccessのODBCドライバ(MDAC2.5)について調べたところ、MDAC2.5を使用したSQL文では二重引用符(”)を文字列リテラルとして使用できないようです。
この問題を回避するよい方法があれば、ぜひ教示願います。
<コーディング内容>
//postされた内容を受け取る
String wkkanri = request.getParameter(“kanri_No”);
String wkroom = request.getParameter(“room_No”);
-------------------------------------------------
//ドライバクラスのロード、DB接続
Class.forName(“sun.jdbc.odbc.JdbcOdbcDriver”);
Connection con = DriverManager.getConnection(“jdbc:odbc:syataku”);
Statement stmt = con.createStatement();
//insert用sql文の発行
String sql = “insert into kihon(kanri_No,room_No) values(wkkanri,wkroom)”;
Stmt.executeUpdate(sql);
No.1ベストアンサー
- 回答日時:
クォートが全角なのは記載ミスですよね。
例えば、wkkanri に K001 、wkroom に 101 とか入っている
として、Accessに渡したいSQLは
insert into kihon(kanri_No,room_No) values('K001',101)
になります。
しかしお書きになった内容は
insert into kihon(kanri_No,room_No) values(wkkanri,wkroom)
なので、Access側ではエラーになります。
String sql に連結させて、正しいSQLを動的に作ってあげないと。
String sql = "insert into kihon(kanri_No,room_No) values('" + wkkanri + "'," + wkroom + ")";
とかでは?
DB側の型がわからないので、その辺は自助努力で。
もしくはパラメータバインドと言う方法もありますが、まずは
今のやり方を完遂させた方がよいでしょう。
全角なのは、環境が別の為、一旦Wordへ打ってそれを貼り付けてしまったからです。油断しました(汗)
頂いたアドバイスを元に何とかDBへの情報登録が出来るようになりました。
御礼が遅くなりましたが、有難う御座いました。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PHP 重複を防ぐ記述について教えて下さい。 3 2023/04/03 14:35
- SQL Server SQL ServerでDBを構築。これは開発? 4 2022/05/28 14:10
- Excel(エクセル) EXCELの外部データ取得ができない 1 2023/03/23 09:03
- PHP PHP MySql ページング 2 2022/09/20 06:38
- CGI perlで書いたcgiでsqliteの使い方を教えてください 2 2023/05/08 21:29
- MySQL #1062 - '0' は索引 'PRIMARY' で重複しています。とでています。 1 2023/01/01 06:13
- その他(プログラミング・Web制作) laravel 本番環境でメールが送れません。 1 2023/02/17 17:57
- その他(プログラミング・Web制作) pythonのグローバル変数 2 2022/11/25 18:02
- MySQL SQLで日付別のIDを生成するには 3 2022/10/09 10:34
- PHP PHP MySQLに画像を直接保存 2 2022/06/05 11:50
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
timestampのデータはどのように...
-
エクセルvbaでpostgresに接続を...
-
SELECT INTOで一度に複数の変数...
-
【SQL】他テーブルに含まれる値...
-
UPDATEで既存のレコードに文字...
-
フラグをたてるってどういうこ...
-
エラーを起こす方法
-
ExcelのVLOOKUP関数の動作をMyS...
-
CSVファイルを読み込んでテーブ...
-
sqlに記述できない文字
-
T-SQLで任意の箇所で強制終了す...
-
テーブル名が可変の場合のクエ...
-
CASEでBETWEEN制約
-
テキストボックスの背景をVB...
-
PRIMARY KEYのコピー
-
複数の条件に該当する結果を、...
-
既にテーブルが存在する場合の...
-
truncate tableを使って複数の...
-
SQLSERVER 連番更新について
-
オラクルのUPDATEで複数テーブル
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
timestampのデータはどのように...
-
エクセルvbaでpostgresに接続を...
-
SQLServer からのデータ移行(v...
-
insert処理でDATE型を追加したい
-
PHPでInsertを実行したら空白の...
-
SERIAL型の省略入力について
-
【SQL】他テーブルに含まれる値...
-
SELECT INTOで一度に複数の変数...
-
フラグをたてるってどういうこ...
-
sqlに記述できない文字
-
テーブル名が可変の場合のクエ...
-
PostgreSQLのtimestamp型で時間...
-
UPDATEで既存のレコードに文字...
-
pandasでsqlite3にテーブル作成...
-
オラクルのUPDATEで複数テーブル
-
truncate tableを使って複数の...
-
エラーを起こす方法
-
SQLで、Join句で結合したテ...
-
Accessで今日から5日後
-
CSVファイルを読み込んでテーブ...
おすすめ情報