2011-07-27 61 views
1

問:的參數(參數化查詢)數目錯誤

當我嘗試執行以下參數化查詢:

INSERT INTO days (day,short,name,depcode,studycode,batchnum) values (?,?,?,?,?,?);SELECT SCOPE_IDENTITY(); 

通過command.ExecuteScalar();

引發以下例外:

錯誤[07001] [Informix .NET提供程序]錯誤的參數數量。

問題出在哪裏?

編輯:

public static int InsertDays(List<Day> days) 
     { 

      int affectedRow = -1; 
      Dictionary<string, string> daysParameter = new Dictionary<string, string>(); 
      try 
      { 
       foreach (Day a in days) 
       { 
        daysParameter.Add("day", a.DayId.ToString()); 
        daysParameter.Add("short", a.ShortName); 
        daysParameter.Add("name", a.Name); 
        daysParameter.Add("depcode", a.DepCode.ToString()); 
        daysParameter.Add("studycode", a.StudyCode.ToString()); 
        daysParameter.Add("batchnum", a.BatchNum.ToString()); 

        affectedRow = DBUtilities.InsertEntity_Return_ID("days", daysParameter); 
        daysParameter.Clear(); 
        if (affectedRow < 0) 
        { 
         break; 
        } 
       } 
      } 
      catch (Exception ee) 
      { 
       string message = ee.Message; 
      } 

      return affectedRow; 

     } 

public static int InsertEntity_Return_ID(string tblName, Dictionary<string, string> dtParams) 
     { 
      int Result = -1; 
      DBConnectionForInformix DAL_Helper = new DBConnectionForInformix(""); 
      string[] field_names = new string[dtParams.Count]; 
      dtParams.Keys.CopyTo(field_names, 0); 
      string[] field_values = new string[dtParams.Count]; 
      string[] field_valuesParam = new string[dtParams.Count]; 
      dtParams.Values.CopyTo(field_values, 0); 
      for (int i = 0; i < field_names.Length; i++) 
      { 
       field_valuesParam[i] = "?"; 
      } 
      string insertCmd = @"INSERT INTO " + tblName + " (" + string.Join(",", field_names) + ") values (" + string.Join(",", field_valuesParam) + ");SELECT SCOPE_IDENTITY();"; 

     Result = int.Parse(DAL_Helper.Return_Scalar(insertCmd)); 
     return Result; 
     } 

+0

應該是不'command.ExecuteNonQuery'? –

+0

@Eben:我懷疑它的的ExecuteScalar由於「SELECT SCOPE_IDENTITY」的一部分。 –

+0

以及您在哪裏添加了參數值?你應該添加一些行來增加'command.Parameters' ... –

回答

3

您還沒有表現出在那裏你實際上是填充參數。鑑於你有合適數量的問號,我懷疑這是問題所在。

編輯:好的,現在你已經發布了更多的代碼,很明顯什麼是錯的:你的Return_Scalar方法不接受任何實際值!你不是填充它後使用field_values任何地方。您需要在命令中設置參數。

(你也應該看看.NET naming conventions,順便......)

+0

我編輯我的問題。 –

+1

@just_name:我編輯了我的答案。你實際上並沒有告訴數據庫使用什麼值。 –

1

確保在您提供的參數值的一個不爲空。這可能會導致提供程序忽略該參數。如果這是您的問題,請通過DBNull

編輯

正如喬恩說你需要使用command.Parameters給予命令,在查詢中使用的參數。

+0

@just_name:編輯添加到Jon說的。 –