背景
最近手头上有比较多项目与Oracle相关,并且需要调用一些Oracle的自定义方法和函数, 最近接触的一个存储过程,无论怎么调用都会出现 【ORA-06502: PL/SQL: numeric or value error: character string buffer too small】 的错误, 而且这个存储过程并非我司同事编写,非常不好调试,最后发现是参数顺序问题, 调整为完全与存储过程定义一致之后,问题解决。
详细描述
这个storeproc大概是这个样子的
sp_demo(O_ERROR_MESSAGE, O_ERROR_CODE, I_DC_CODE, I_STORE_CODE, I_ADJ_NO) ;
返回的是一个NUMBER类型。 (原来是BOOLEAN,但是众所周知.NET 与ORACLE 的BOOLEAN类型实在有点不太对付, 所以改成了NUMBER).
参数大概是这样子的
O_ERROR_MESSAGE INOUT VARCHAR2(4000)
O_ERROR_CODE INOUT NUMBER(10)
I_DC_CODE IN VARCHAR2(10)
I_STORE_CODE IN VARCHAR2(20)
I_ADJ_NO IN NUMBER(10)
而我的C# Code 大概是这样子
OracleCommand cmd = new OracleCommand();
cmd.Connection = conn;
cmd.CommandText = "sp_demo";
cmd.CommandType = CommandType.StoredProcedure;
OracleParameter p1 = new