oracle编码储存过程,从Oracle存储过程获取值

我有一个Oracle过程,它将返回所有参数的串联字符串

create or replace procedure tin_builder (type in varchar2,

tin_serial in number, rand_digit in varchar2, tin out varchar2 ) is

BEGIN

tin := type || TO_CHAR(tin_serial) || rand_digit ;

END

现在,我想从Visual Studio 2008调用该过程(C代码)

public void TinBuilder(string type, long tin_serial, string rand_digit)

{

OracleConnection connection = new OracleConnection("Data Source=xe;User ID=system;Password=******;");

OracleCommand cmd = new OracleCommand();

cmd.Connection = connection;

cmd.CommandText = "tin_builder";

cmd.CommandType = CommandType.StoredProcedure;

cmd.Parameters.Add("type", OracleDbType.Varchar2).Value = type;

cmd.Parameters.Add("tin_serial", OracleDbType.Decimal).Value = tin_serial;

cmd.Parameters.Add("rand_digit", OracleDbType.Varchar2).Value = rand_digit;

cmd.Parameters.Add("tin", OracleDbType.Varchar2).Direction = ParameterDirection.ReturnValue;

try

{

connection.Open();

cmd.ExecuteNonQuery();

TextBox1.Text = cmd.Parameters["tin"].Value.ToString();

}

catch (Exception ex)

{

}

finally

{

connection.Close();

}

}

然后用:

TinBuilder("1", 10000001, "37");

但它不在文本框中显示任何值:(。请有人帮帮我。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值