

VB.Netからストアドプロシージャを実行するプログラムの書き方がよく分かりません。
データベースはOracleです。
PROCEDURE test(aaa IN number, bbb IN varvhar2, ccc IN OUT varchar2);
といったPL/SQLをVB.NET上で実行するとします。
(略:データベースへの接続処理)
strSql = "begin test(10, 'テスト', '');end;"
結果「式が割り当てられていません」とエラーが出ます。
すべての引数がINのプロシージャでは、上記の方法で実行できたので、IN OUTへの引数の渡し方に問題があると思うのですが、どうしても分かりません。
まだ使い始めたばかりで、どうしていいかまったく分からない状態です。
どうかご指導お願い致します。
No.1ベストアンサー
- 回答日時:
こんにちは、じゃんぬねっと です。
流れとしては、
・OracleCommand のインスタンスを正しく生成。
・CommandText に、プロシージャ名を設定する
・CommandType に、CommandType.StoredProcedure を設定。
・Parameters にパラメタを Add する。
・初期値を Value に設定する
・ExecuteNonQuery あたりを実行。
・オブジェクトの解放
この回答への補足
返信ありがとうございます。
以下の方法で試してみました。
Dim con As New OracleConnection
Dim cmd As OracleCommand
cmd = New OracleCommand("test", con)
cmd.CommandType = CommandType.StoredProcedure
Dim aaa As OracleParameter = _
cmd.Parameters.Add("aaa", OracleDbType.Int32,ParameterDirection.Input)
acc.Value = 10
Dim bbb As OracleParameter = _
cmd.Parameters.Add("bbb", OracleDbType.Varchar2,ParameterDirection.Input)
acc.Value = "テスト"
Dim ccc As OracleParameter =
cmd.Parameters.Add("ccc", OracleDbType.Varchar2,255,DBNull.Value,ParameterDirection.InputOutput)
ccc.Value = ""
cmd.ExecuteNonQuery()
cmd.Dispose()
実行の結果、"列に格納する値が大きすぎます"でエラーになります。
何のサイズのことを指しているのか、よく分かりません。
書き方以外でも見落としている箇所がございましたら、よろしくお願い致します。
補足ですが、OracleへはODP.NETで接続しています。
解決しました!
列の大きさはデータベース側の問題で、そちらを調べてみることでうまくいきました。
データベース自体もまったく理解ができていなかったので、じゃんぬねっとさんには丁寧に流れを教えていただいて感謝しています。
いろんなエラー出したので、少しだけ分かりかけてきました。
ありがとうございました!
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
[teraterm] waitコマンドで停止...
-
exeファイルを実行するとコマン...
-
VBscriptが起動しない?
-
バッチファイルの内容を表示さ...
-
これってパソコンの最適化が完...
-
VBScriptでコマンドプロンプト...
-
エクセル フォルダの画像を画...
-
「読み取りと実行」と「読み取...
-
複数のbatファイルを自動実行し...
-
Excel VBA ステップインが途中...
-
実行中のログをフォームのテキ...
-
VScodeのエラー解決法 Pythonの...
-
VBScript(WHS)でWMIを使ってリ...
-
Excelのセルの内容をコマンドプ...
-
VBAから複数のバッチファイルを...
-
pythonスクリプトを管理者権限...
-
batからexeを実行し戻り値を受...
-
シェルスクリプトを実行したい
-
vbscriptを用いて他のVBSファイ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
コマンドプロンプトのエラーに...
-
[teraterm] waitコマンドで停止...
-
複数のbatファイルを自動実行し...
-
これってパソコンの最適化が完...
-
Windows System32 Security Hea...
-
「読み取りと実行」と「読み取...
-
バッチファイルの内容を表示さ...
-
VBscriptが起動しない?
-
exeファイルを実行するとコマン...
-
Access の VBA 実行中に他の操...
-
Excel(エクセル) VBA プロシー...
-
PDFファイルを開き、印刷し、閉...
-
ネットワーク名が見つかりません
-
pythonスクリプトを管理者権限...
-
エクセル フォルダの画像を画...
-
VBScriptでコマンドプロンプト...
-
Excel VBA ステップインが途中...
-
WSH.Run の処理内容をテキスト...
-
バッチファイルが不正終了して...
-
ExcelのVBAが特定のPC上でのみ...
おすすめ情報