asp.net调用Oracle存储过程传递参数问题

BevisLiao 2015-10-16 02:43:20
asp.net调用Oracle存储过程报错,错误信息如下:

调用无参的存储过程,没有问题。调用有参数的存储过程后,就报上面的错误。存储过程都已测试,没有问题。

UI层调用代码:
protected void Button1_Click(object sender, EventArgs e)
{
//flowManage.ChangeType();
flowManage.ChangeType(TextBox1.Text.Trim());
}


数据访问层:
public int ChangeType(string id)
{
//OracleParameter[] pms = {
// new OracleParameter("FLOWID", OracleType.Number,4)

// };
//pms[0].Value = id;
OracleParameter pms = new OracleParameter(":FLOWID", OracleType.VarChar,15);
pms.Value = id;

return OracleHelper.ExecuteNonQuery("test2",CommandType.StoredProcedure,pms);
}
//这是无参的存储过程,调用这个存储过程没有问题。
public int ChangeType()
{
return OracleHelper.ExecuteNonQuery("test", CommandType.StoredProcedure, null);
}

DBHelper中的方法:
public static int ExecuteNonQuery(string cmdText, CommandType cmdType, params OracleParameter[] pms)
{
using (OracleConnection con = new OracleConnection(connStr))
{
using (OracleCommand cmd = new OracleCommand(cmdText, con))
{
//设置当前执行的是存储过程还是带参数的Sql语句
cmd.CommandType = cmdType;
if (pms != null)
{
cmd.Parameters.AddRange(pms);
}
con.Open();
return cmd.ExecuteNonQuery();
}
}
}

//存储过程
create or replace procedure test2(id in varchar2) is

begin
update dc_xc_flow set flowtype=1 where flowid =id;

end;

...全文
104 1 打赏 收藏 转发到动态 举报
写回复
用AI写文章
1 条回复
切换为时间正序
请发表友善的回复…
发表回复
feiyun0112 2015-10-16
  • 打赏
  • 举报
回复
oracale不熟,但是参数名至少应该是id吧

62,046

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧