C# と VB.NET の質問掲示板

ASP.NET、C++/CLI、Java 何でもどうぞ

C# と VB.NET の入門サイト

Re[1]: refcursorを読み込む処理


(過去ログ 61 を表示中)

[トピック内 2 記事 (1 - 2 表示)]  << 0 >>

■35236 / inTopicNo.1)  refcursorを読み込む処理
  
□投稿者/ まっさん (1回)-(2009/04/22(Wed) 17:39:28)

分類:[.NET 全般] 

ASP.NET初心者です。

オラクルのパッケージからrefcursorを返して
それを.NETで読みこむ処理を作成しています。

パッケージのストアドプロシージャをSQL PLUSからの実行すると
正しい結果が返りエラーも無いのですが

.NETのプログラムから実行するとreader.Read()で
以下のエラーがでます。

{"ORA-00600: 内部エラー・コード、引数: [kcbz_check_objd_typ_1],[0],[0],[1],[],[],[],[]"}

解決方法または根本的に何か間違ってる等ありましたら
教えていただけると助かります。

よろしくお願いいたします。

-------------------------

OracleConnection con = new OracleConnection();
OracleCommand cmd;

con.ConnectionString = "User Id=abc;Password=abc;Data Source=aabbcc";
con.Open();

cmd = new OracleCommand();
cmd.Connection = con;
cmd.CommandType = CommandType.StoredProcedure;

cmd.CommandText = "PKG_GRAPH_DATA.getGraphD";

OracleParameter outPara = new OracleParameter("GraphCursor", OracleDbType.RefCursor);
outPara.Direction = ParameterDirection.Output;
cmd.Parameters.Add(outPara);

cmd.Parameters.Add("code1", OracleDbType.Varchar2).Value = "1300";
cmd.Parameters.Add("code2", OracleDbType.Varchar2).Value = "1310";
cmd.Parameters.Add("code3", OracleDbType.Varchar2).Value = "1320";

OracleDataReader reader = cmd.ExecuteReader();

while (reader.Read()) ←ここでエラーです。(一件も読めずにいきなりエラー)
{
}

cmd.Dispose();
con.Close();
con.Dispose();
引用返信 編集キー/
■35261 / inTopicNo.2)  Re[1]: refcursorを読み込む処理
□投稿者/ オショウ (164回)-(2009/04/22(Wed) 22:57:34)
2009/04/22(Wed) 22:58:11 編集(投稿者)

> OracleParameter outPara = new OracleParameter("GraphCursor", OracleDbType.RefCursor);
> outPara.Direction = ParameterDirection.Output;
> cmd.Parameters.Add(outPara);
>
> cmd.Parameters.Add("code1", OracleDbType.Varchar2).Value = "1300";
> cmd.Parameters.Add("code2", OracleDbType.Varchar2).Value = "1310";
> cmd.Parameters.Add("code3", OracleDbType.Varchar2).Value = "1320";

  ここのparametersの与え方が間違っていると思います。
  ODP.NETもADO.NETも基本的にこのような文法は同じだと思いますので。

  http://rararahp.blog69.fc2.com/blog-entry-65.html

  ここのコードを見てもらえたら解ると思いますが・・・

※ 因みに、私はODP.NETは使ったことありません。残念ながら。

以上。
引用返信 編集キー/


トピック内ページ移動 / << 0 >>

このトピックに書きこむ

過去ログには書き込み不可

管理者用

- Child Tree -