PLS-00306: 调用 'Pro_XXXXXXXXXX' 时参数个数或类型错误小计

 "ORA-06550: 第 1 行, 第 7 列: /nPLS-00306: 调用 'Pro_XXXXXXXXXX' 时参数个数或类型错误/nORA-06550: 第 1 行, 第 7 列: /nPL/SQL: Statement ignored/n"

采用C#写的客户端调用,程序如下,其中有Number参数。

 

  1.                 System.Data.OracleClient.OracleParameter[] mOP = new System.Data.OracleClient.OracleParameter[5];
  2.                 mOP[0] = new System.Data.OracleClient.OracleParameter("Field1", System.Data.OracleClient.OracleType.VarChar, 32);
  3.                 mOP[1] = new System.Data.OracleClient.OracleParameter("Field2", System.Data.OracleClient.OracleType.Number);
  4.                 mOP[2] = new System.Data.OracleClient.OracleParameter("Field3", System.Data.OracleClient.OracleType.Number);
  5.                 mOP[3] = new System.Data.OracleClient.OracleParameter("Field4", System.Data.OracleClient.OracleType.Number);
  6.                 mOP[4] = new System.Data.OracleClient.OracleParameter("Field5", System.Data.OracleClient.OracleType.Number);
  7.                 mOP[0].Direction = System.Data.ParameterDirection.Input;
  8.                 mOP[1].Direction = System.Data.ParameterDirection.Input;
  9.                 mOP[2].Direction = System.Data.ParameterDirection.Input;
  10.                 mOP[3].Direction = System.Data.ParameterDirection.Output;
  11.                 mOP[4].Direction = System.Data.ParameterDirection.Output;
  12.                 mOP[0].Value = "123";
  13.                 mOP[1].Value = "456";
  14.                 mOP[2].Value = null;
  15.                 mOP[3].Value = null;
  16.                 mOP[4].Value = null;

按如上的写法,则报错,如果把mOP[2].Value = null;改成mOP[2].Value = 0;,则顺利通过。

 

究其原因,应该是为In的参数,如果是数值型的填入了非数值型数据,包括Null,则无法转换。

 

同理,我认为针对Date类型的也有可能发生这样的问题

 

 

 

你可能感兴趣的:(Date,C#,null)