2011-07-27 12 views
1

Q:間違った数(パラメータ化クエリ)

私は、次のパラメータ化クエリを実行しよう:command.ExecuteScalar();

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

は、次の例外がスローされます。

ERROR [07001] [Informix .NETプロバイダ]パラメータの数が間違っています。

問題がありますか?

EDIT:あなたが実際にパラメータにを移入している場所を示していない

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:私はそれが原因「SCOPE_IDENTITYを選択」の部分には、ExecuteScalarだと思われます。 –

+0

と、どこにパラメータ値を追加しましたか? () 'いいえ、彼は選択の' SCOPE_IDENTITYを、ので、彼はそれから返された値を(あなたが右にスクロールする必要があります)を期待:あなたはcommand.Parameters' ... –

答えて

3

。適切な数の疑問符があることを考えれば、問題がどこにあるのか疑問に思う。

EDIT:さて、あなたはより多くのコードを掲載しました、それは間違っている何が起こっているのは明らかだ:あなたのReturn_Scalar方法は、任意の実際の値を受け付けていません!あなたはそれを移入した後、どこにでもfield_valuesを使用していないいます。コマンドでパラメータを設定する必要があります。

(あなたがも...仕方によって、.NET naming conventionsをご覧ください)

+0

私は私の質問を編集します。 –

+1

@just_name:私は自分の答えを編集しました。あなたは実際に使用する値をデータベースに伝えていません。 –

1

あなたが値のいずれかがnullではないことをパラメータを提供しているところことを確認してください。そのため、プロバイダはパラメータを無視する可能性があります。これが問題の場合はDBNullを渡してください。

EDIT

ジョンは、クエリで使用するコマンドにパラメータを与えることcommand.Parametersを使用する必要が述べたように。

+0

@just_name:ジョンが言ったことに加えて編集しました。 –

関連する問題