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类型的也有可能发生这样的问题

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值