"ORA-06550: 第 1 行, 第 7 列: /nPLS-00306: 调用 'Pro_XXXXXXXXXX' 时参数个数或类型错误/nORA-06550: 第 1 行, 第 7 列: /nPL/SQL: Statement ignored/n"
采用C#写的客户端调用,程序如下,其中有Number参数。
- System.Data.OracleClient.OracleParameter[] mOP = new System.Data.OracleClient.OracleParameter[5];
- mOP[0] = new System.Data.OracleClient.OracleParameter("Field1", System.Data.OracleClient.OracleType.VarChar, 32);
- mOP[1] = new System.Data.OracleClient.OracleParameter("Field2", System.Data.OracleClient.OracleType.Number);
- mOP[2] = new System.Data.OracleClient.OracleParameter("Field3", System.Data.OracleClient.OracleType.Number);
- mOP[3] = new System.Data.OracleClient.OracleParameter("Field4", System.Data.OracleClient.OracleType.Number);
- mOP[4] = new System.Data.OracleClient.OracleParameter("Field5", System.Data.OracleClient.OracleType.Number);
- mOP[0].Direction = System.Data.ParameterDirection.Input;
- mOP[1].Direction = System.Data.ParameterDirection.Input;
- mOP[2].Direction = System.Data.ParameterDirection.Input;
- mOP[3].Direction = System.Data.ParameterDirection.Output;
- mOP[4].Direction = System.Data.ParameterDirection.Output;
- mOP[0].Value = "123";
- mOP[1].Value = "456";
- mOP[2].Value = null;
- mOP[3].Value = null;
- mOP[4].Value = null;
按如上的写法,则报错,如果把mOP[2].Value = null;改成mOP[2].Value = 0;,则顺利通过。
究其原因,应该是为In的参数,如果是数值型的填入了非数值型数据,包括Null,则无法转换。
同理,我认为针对Date类型的也有可能发生这样的问题