也谈Oracle异常: ORA-06502: PL/SQL: 数字或值错误 : 字符串缓冲区太小
2015-05-29 18:20
471 查看
场景:
.Net程序调用Oracle方法 command.ExecuteNonQuery()执行存储过程;弹出如标题异常信息。
存储过程有4个输入参数,一个输出参数。一旦执行到给输出参数赋值的时候就报错。但在Plsql环境下调度,是正常的。
分析:
查阅各帖子,都说是变量长度不够,但设置也无果。
后来,怀疑是不是设置参数顺序有问题,调整,搞定。
解决:
存储过程中定义的参数,第一个为out,虽然在设置参数时,用了参数名,但好像没起什么作用。所以,把输出参数第一个设置,与定义顺序一致,就OK了。
另外:输出参数长度是必须指定的。这里,我是通过给定一个无意义的初始值(做占位符用)。
//定义输出参数
Dictionary<string, object> dicOut = new Dictionary<string, object>();
dicOut.Add("djdh", "11111111111111111111");
定义存储过程:
CREATE OR REPLACE PROCEDURE gendh(djdh OUT VARCHAR2,
djlx IN VARCHAR2,
rq IN VARCHAR2,
dwdm IN VARCHAR2,
csfs IN VARCHAR2) IS……
后台服务中的存储过程方法定义:
// 设置输出参数
foreach (KeyValuePair<string, object> kvp in dicParaOut)
{
command.Parameters.Add(kvp.Key, OracleDbType.Varchar2, kvp.Value.ToString().Length).Direction = ParameterDirection.Output;
}
//设置输入参数
foreach (KeyValuePair<string, object> kvp in dicIn)
{
command.Parameters.Add(kvp.Key, OracleDbType.Varchar2, kvp.Value, ParameterDirection.Input);
}
.Net程序调用Oracle方法 command.ExecuteNonQuery()执行存储过程;弹出如标题异常信息。
存储过程有4个输入参数,一个输出参数。一旦执行到给输出参数赋值的时候就报错。但在Plsql环境下调度,是正常的。
分析:
查阅各帖子,都说是变量长度不够,但设置也无果。
后来,怀疑是不是设置参数顺序有问题,调整,搞定。
解决:
存储过程中定义的参数,第一个为out,虽然在设置参数时,用了参数名,但好像没起什么作用。所以,把输出参数第一个设置,与定义顺序一致,就OK了。
另外:输出参数长度是必须指定的。这里,我是通过给定一个无意义的初始值(做占位符用)。
//定义输出参数
Dictionary<string, object> dicOut = new Dictionary<string, object>();
dicOut.Add("djdh", "11111111111111111111");
定义存储过程:
CREATE OR REPLACE PROCEDURE gendh(djdh OUT VARCHAR2,
djlx IN VARCHAR2,
rq IN VARCHAR2,
dwdm IN VARCHAR2,
csfs IN VARCHAR2) IS……
后台服务中的存储过程方法定义:
// 设置输出参数
foreach (KeyValuePair<string, object> kvp in dicParaOut)
{
command.Parameters.Add(kvp.Key, OracleDbType.Varchar2, kvp.Value.ToString().Length).Direction = ParameterDirection.Output;
}
//设置输入参数
foreach (KeyValuePair<string, object> kvp in dicIn)
{
command.Parameters.Add(kvp.Key, OracleDbType.Varchar2, kvp.Value, ParameterDirection.Input);
}
相关文章推荐
- Oracle数据库连接
- oracle常用SQL
- 手工创建oracle数据库
- Oracle的用户解锁与修改密码
- Oracle ORA-错误查询文档10gR2(全)
- Oracle Merge 介绍
- oracle lob move tablespace
- oracle设置定时任务来调用存储过程完成统计(每小时计时一次存到hour表)
- Oracle学习(2):过滤和排序
- Oracle数据库PLSQL的中文乱码显示全是问号
- ORACLE数据库中的表连接关系
- zabbix 之 orabbix安装指导
- Oracle备份常用命令
- oracle 网址
- Oracle学习(四)之设置内存参数
- (转)oracle表空间使用率统计查询
- oracle之报错:ORA-00054: 资源正忙,要求指定 NOWAIT
- Oracle中使用fnd_log_messages调试的步骤
- 去重oracle
- 蜀中猿从学oracle,02,时间2015-5-15