Неверное количество параметров (параметризованный запрос) - PullRequest
1 голос
/ 27 июля 2011

Q:

Когда я пытаюсь выполнить следующий параметризованный запрос:

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;
        }

Ответы [ 2 ]

3 голосов
/ 27 июля 2011

Вы не указали, где вы на самом деле заполняете параметр значения . Учитывая, что у вас правильное количество вопросительных знаков, я подозреваю, что именно в этом проблема.

РЕДАКТИРОВАТЬ: Хорошо, теперь вы разместили больше кода, очевидно, что идет не так: ваш Return_Scalar метод не принимает никаких фактических значений! Вы не используете field_values в любом месте после его заполнения. Вам необходимо установить параметры в команде.

(Кстати, обратите внимание на соглашения об именах .NET , кстати ...)

1 голос
/ 27 июля 2011

Убедитесь, что в тех случаях, когда вы предоставляете параметры, одно из значений не является нулевым. Это может привести к тому, что провайдер проигнорирует параметр. Если это ваша проблема, пройдите DBNull.

EDIT

Как сказал Джон, вам нужно использовать command.Parameters, чтобы дать команде параметры, которые будут использоваться в запросе.

...