ODP.NET的ODAC组件使用输出参数(Out Parameter)时注意事项

本文介绍在使用OracleCommand添加ParameterDirection.Out输出参数时遇到的问题:Varchar2类型的参数输出为空字符串。通过设置OracleParameter的Size属性解决了该问题。

最近使用Oracle的ODAC组件编写数据组件时候发现,在向OracleCommand中添加一个ParameterDirection.Out的输出参数,发现数值类型输出正常,Varchar2类型出来的全部是空字符串(不是DBNull)。

CommandText:

update TABLE set STATUS=123
returning ID, NAME into :oId, :oName
Code:
comm.Parameters.Add(":oId", OracleDbType.Int32, ParameterDirection.Output);
comm.Parameters.Add(":oName", OracleDbType.Varchar2, ParameterDirection.Output);

这个看起来毫无问题的代码,在跑的过程中却出现问题,输出参数“:oId”输出正常,但“:oName”却是空字符串。

几经调试毫无头绪,Google之,也没有什么具体回答,直到我看到一篇帖子(忘记具体说什么的了),提到设置OracleParameter中的Size属性,顿时想起调试时候OracleParameter中的Size值是0。

果断设之,输出正常!

Code:

comm.Parameters.Add(":oName", OracleDbType.Varchar2, ParameterDirection.Output).Size = 64;


PS:Size设大了只会浪费服务器上的一点点内存空间,而且在数据返回的时候会自动设定数据的大小为Size值;如果设小了就会截断返回的数据。这个需要自己衡量了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值