2

我正在创建一个查询,我似乎无法超越Not all variables boundOracle 中的错误

据我所知,一切看起来都是正确的。我错过了什么?

为了保护无辜者,代码有点模糊......

OracleCommand execCmd = new OracleCommand();

OracleParameter outParam =
        new OracleParameter("ID", OracleType.Int32);
outParam.Value = DBNull.Value;
outParam.Direction = System.Data.ParameterDirection.Output;
execCmd.CommandText = "insert into o " +
        "(A, B, " +
        "C, D, E, " +
        "F, G, H, I, " +
        "J, K) " +
        "VALUES (:A, :B, :C, :D, :E, " +
        ":F, :G, :H, :I, :J, :K) " +
        "RETURNING O_ID INTO :ID";
execCmd.Parameters.AddWithValue("A", og.N);
execCmd.Parameters.AddWithValue("B", DBNull.Value);
execCmd.Parameters.AddWithValue("C", DBNull.Value);
execCmd.Parameters.AddWithValue("D", og.A);
execCmd.Parameters.AddWithValue("E",
    og.A1 + " " + og.A2 + " " + og.A3 +
    " " + og.C);
execCmd.Parameters.AddWithValue("F", DBNull.Value);
execCmd.Parameters.AddWithValue("G", DBNull.Value);
execCmd.Parameters.AddWithValue("H", og.Cs);
execCmd.Parameters.AddWithValue("I", ss);
execCmd.Parameters.AddWithValue("J", DBNull.Value);
execCmd.Parameters.AddWithValue("K", "N");
execCmd.Parameters.Add(outParam);
conn.executeCommand(execCmd, trx);
4

3 回答 3

6

我最终能够解决这个问题。原来我的一个字符串实际上是空的,并且这个版本OracleCommand(标记为已弃用)中存在一个错误,导致它删除空参数。我的解决方案是在执行之前运行修复功能。

此外,正如其他人所说,订单确实很重要。所以,这也必须是正确的。

这对我有用,在执行之前调用它:

private void PopulateNullParameters(OracleCommand cmd)
{
    foreach (OracleParameter p in cmd.Parameters)
    {
        if (p.Value == null)
        {
            p.Value = DBNull.Value;
        }
    }
}
于 2012-11-01T13:22:03.520 回答
1

在最后一行中,您似乎缺少 ID 参数:

"RETURNING ORGANIZATION_ID INTO :ID";

此外,基于这个 SO question,看来 OracleCommand 对象按位置绑定参数,因此如果您的参数无序,您可能需要查看使用BindByName属性:

using(OracleCommand cmd = con.CreateCommand()) {
    ...
    cmd.BindByName = true;
    ...
}
于 2012-10-31T19:32:24.457 回答
0

尝试在参数名称前加上:冒号

例如

  execCmd.Parameters.AddWithValue(":NAME", org.Name);
  execCmd.Parameters.AddWithValue(":EDP", DBNull.Value);
  execCmd.Parameters.AddWithValue(":EDD", DBNull.Value);
  execCmd.Parameters.AddWithValue(":ACRONYM", org.Acronym);    
  ....
于 2012-11-01T00:22:47.123 回答