0

我正在尝试使用 ADO.NET 向 Interbase XE 数据库发出参数化的 SELECT。我正在使用的代码如下:

using (OdbcConnection odbcConnection = new OdbcConnection(ConfigurationManager.ConnectionStrings["LawbaseTest"].ToString()))
      {
        odbcConnection.Open();
        using (OdbcCommand odbcCommand = new OdbcCommand())
        {
          odbcCommand.CommandType = CommandType.Text;
          odbcCommand.Connection = odbcConnection;
          odbcCommand.Parameters.Add(new OdbcParameter(":CaseNumber", 1265));
          odbcCommand.CommandText = "select * from cmstub where cm_recnum = :CaseNumber";
          using (IDataReader rdrData = odbcCommand.ExecuteReader())
          {
            Output(rdrData["CM_DESC"]);
          }
        }
      }

我收到以下错误:

ERROR [42S22] [DataDirect][ODBC InterBase driver][InterBase]Dynamic SQL Error, SQL error code = -206, Column unknown, CASENUMBER

这向我表明,查询没有以它识别为参数化查询的语法发送到 Interbase。

这比我预期的要难。我是个ficko吗?你能帮我吗?

4

1 回答 1

0

命名参数不受广泛支持似乎是常态,您尝试使用吗?相反,即 cm_recnum = :CaseNumber to cm_recnum = ?

于 2011-06-15T13:14:44.567 回答