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

最近使用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值;如果设小了就会截断返回的数据。这个需要自己衡量了。

你可能感兴趣的:(.Net,C#,Oracle)