No.2ベストアンサー
- 回答日時:
先の回答が的を得ていたようで良かったです。
(^^)お察しの通りここでの「SP030」はストアドの名称です。このストアドの引数はSP030( in, in, out )とお考え下さい。
con.prepareCall("{call SP030(?,?,?)}");
の?はバインド変数の意味です。なのでコード自体は?のまま記述します。
その下の
para.setString( 1, "0" );
で一番最初の?に入れるものを指定します。一番目なので引数に「1」と書いてあります。次の引数の「"0"」は?に入る値です。
なのでそこが変数でも関数の戻り値でも良いわけです。
そしてそして次の行の
para.setString( 2, "0" );
は二番目の?に「"0"」を入れますと言う意味です。
その次の行
para.registerOutParameter( 3, java.sql.Types.CHAR );
は三番目の?はストアドのパラメータがoutなのでストアドからもらえる値です。
「java.sql.Types.CHAR」はもらえる値がchar型ですよ、と示しているわけです。
そして最後に
para.execute();
でストアドが実行されます。
outの値を取得する場合は実行した後に
Sting val1 = para.getString(3);
と記述すると、変数val1にoutを取得することができます。
うーん、わかりにくい!!(^^;
わかりにくかったらまた根ほり葉ほり聞いて下さい。(笑)
返事が大変に遅れて申し訳ありません。
仕事に追われるうちに今日に至ってしまいました。。。
2度に渡ってのご親切な回答ありがとうございます。
お蔭様で、なんとかなりました!
いやいや、本当に助かりました。
今回も根掘り葉掘り聞こうと思ったのですが、
是非次回にでもと思います。(すいません、調子に乗りすぎました。。。)
それでは、本当にありがとうございました。
敬具
No.1
- 回答日時:
引数のSQLという表現がよくわからなかったのですが、ただ単にストアドの引数をどうやってかけばいいのか
ということでよいのでしょうか?(ちなみにJDK1.3使用)
Connection con~中略~
CallableStatement para = con.prepareCall("{call SP030(?,?,?)}");
para.setString( 1, "0" );
para.setString( 2, "0" );
para.registerOutParameter( 3, java.sql.Types.CHAR );
para.execute();
EJBのことはよくわかりませんが、上記のようにinはsetStringを使用して
outはregisterOutParameterを使用すればいいようです。
的が大外れしていたらすみません。<(_ _)>
ちなみにoutは上記であれば「para.getString(3)」でとりだせるようです。
どうもありがとうございます。
言い方が悪くてすいませんでした。。。
>CallableStatement para = con.prepareCall("{call SP030(?,?,?)}");
↑の「"{call SP030(?,?,?)}"」部分が知りたかったんです。
「SP030」はプロシージャのファイル名でいいんですか?
あと、3つの「?」のところにそれぞれ何が入るのでしょうか?
多分、テーブル名と、カラム名と、データをセットするのでしょうか?
もし、その場合には、「(1,2,3)」としたら順番はどうなるんでしょうか?
せっかく、教えていただいてまた根掘り葉掘り聞いてしまって
申し訳ありませんが、時間があるときにでも教えてください。
よろしくお願いします。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・人生のプチ美学を教えてください!!
- ・10秒目をつむったら…
- ・あなたの習慣について教えてください!!
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・【大喜利】【投稿~9/18】 おとぎ話『桃太郎』の知られざるエピソード
- ・街中で見かけて「グッときた人」の思い出
- ・「一気に最後まで読んだ」本、教えて下さい!
- ・幼稚園時代「何組」でしたか?
- ・激凹みから立ち直る方法
- ・1つだけ過去を変えられるとしたら?
- ・【あるあるbot連動企画】あるあるbotに投稿したけど採用されなかったあるある募集
- ・【あるあるbot連動企画】フォロワー20万人のアカウントであなたのあるあるを披露してみませんか?
- ・映画のエンドロール観る派?観ない派?
- ・海外旅行から帰ってきたら、まず何を食べる?
- ・誕生日にもらった意外なもの
- ・天使と悪魔選手権
- ・ちょっと先の未来クイズ第2問
- ・【大喜利】【投稿~9/7】 ロボットの住む世界で流行ってる罰ゲームとは?
- ・推しミネラルウォーターはありますか?
- ・都道府県穴埋めゲーム
- ・この人頭いいなと思ったエピソード
- ・準・究極の選択
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
split関数で区切り文字がない場合
-
eclipseでスタックサイズを変更...
-
コミット前の更新データをチェ...
-
JAVAにのeclipseに関する質問で...
-
Javascriptの値をJava(JSP)へ渡...
-
Eclipse(JAVA)のデバッグで他...
-
「ワークスペースをビルド中」...
-
環境変数設定で
-
java 外部プログラムの実行
-
Google Colabでimport soxが出...
-
Javaで年月の取得(YYYYMM形式で)
-
jasper.exceptionとは?
-
jdbcでinsert,delete,createをe...
-
JAVA(またはTOMCAT)でのスケ...
-
[JAVA]evalで文字列を計算式に!
-
Eclipseでプログラム実行時に引...
-
javaを実行するにはサーバーが...
-
NoClassDefFoundError: javax/m...
-
バイナリーコードと、ソースコ...
-
JavaScriptにおけるORACLEのSQL...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
split関数で区切り文字がない場合
-
Javascriptの値をJava(JSP)へ渡...
-
eclipseでスタックサイズを変更...
-
「ワークスペースをビルド中」...
-
Javaで年月の取得(YYYYMM形式で)
-
jdbcでinsert,delete,createをe...
-
JAVAにのeclipseに関する質問で...
-
Eclipse(JAVA)のデバッグで他...
-
環境変数設定で
-
コミット前の更新データをチェ...
-
eclipseのjavaを実行できない
-
jasper.exceptionとは?
-
Worksheet_Changeが動かない
-
javascriptで、style undefined...
-
Eclipseで実行>Javaアプリケー...
-
エクリプスで実行時、最新クラ...
-
NoClassDefFoundError: javax/m...
-
Javascriptのパーミッション
-
eclipseで「サーバーで実行」表...
-
Eclipseで実行できてコマンドプ...
おすすめ情報