最近使用Oracle的ODAC组件编写数据组件时候发现,在向OracleCommand中添加一个ParameterDirection.Out的输出参数,发现数值类型输出正常,Varchar2类型出来的全部是空字符串(不是DBNull)。
CommandText:
update TABLE set STATUS=123
returning ID, NAME into :oId, :oNameCode: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值;如果设小了就会截断返回的数据。这个需要自己衡量了。

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

被折叠的 条评论
为什么被折叠?



