.Net / C# - Oracle SQL并非所有变量绑定 - 托管数据访问

时间:2018-02-07 05:28:05

标签: c# oracle oracle-manageddataaccess

我对SQL的Oracles风格比较陌生。我无法弄清楚为什么会返回以下异常:

  

Oracle.ManagedDataAccess.Client.OracleException(0x80004005):   ORA-01008:并非所有变量都绑定

                    OracleCommand cmd1 = con.CreateCommand();
                    cmd1.CommandType = CommandType.Text;
                    cmd1.CommandText = @"MERGE INTO SECURITY_PRICES$V tgt USING (select * from DUAL) src ON (src.DTE = tgt.DTE AND src.SECURITY = tgt.SECURITY AND src.SOURCE = tgt.SOURCE) WHEN MATCHED THEN UPDATE SET tgt.TYPE = 'I', tgt.SOURCE = src.Source, tgt.CURRENCY = 'JMD' ,tgt.SECURITY = src.Security, tgt.LAST_PRICE = :Close, tgt.HIGH_PRICE = :High, tgt.LOW_PRICE = :Low, tgt.DTE = src.DTE, tgt.Volume = :Vol WHEN NOT MATCHED THEN INSERT (TYPE, SOURCE, CURRENCY, SECURITY, LAST_PRICE, HIGH_PRICE, LOW_PRICE, DTE, Volume) VALUES ('I', 'E', 'JMD', :insID,:Close,:High, :Low, :Time, :Vol)";


                    cmd1.Parameters.Add("insID", secid);
                    cmd1.Parameters.Add("Close", data.Close);
                    cmd1.Parameters.Add("High", data.High);
                    cmd1.Parameters.Add("Low", data.Low);
                    cmd1.Parameters.Add("Time", data.Time);
                    cmd1.Parameters.Add("Vol", data.Volume);

                    int suc = cmd1.ExecuteNonQuery();

我尝试了以下内容。将冒号(':')添加到parameters.add。使用较少的变量,确保它没有传入空参数。

这是数据。它被解析为一个对象,每个属性都是一个字符串。 oracle是否需要强类型参数?传入MS SQL Server中的字符串不会导致问题 - 这是我唯一的猜测。

  • insID:228IL
  • 低:0
  • 高0
  • 时间:2018-01-29T13:05:26
  • Vol:0
  • 关闭:0

1 个答案:

答案 0 :(得分:1)

尝试将此行添加到开场代码中:

OracleCommand cmd1 = con.CreateCommand();
cmd1.BindByName = true;
cmd1.CommandType = CommandType.Text;

如果我记得,如果没有设置BindByName,那么OracleCommand类将按照提交的顺序绑定查询中的参数,而不是按名称绑定。因此,由于您对SQL字符串中的某些绑定占位符有多种用法,因此需要再次绑定它们 - 导致"并非所有变量绑定"异常。