Arhn - архитектура программирования

Оператор SQL SET Параметры C#

Я работаю на С# с SQL, и у меня возникают проблемы с выяснением того, как передать переменную С# в инструкцию SQL SET. Я понимаю, как передать параметр в раздел "WHERE" оператора SQL SELECT, но не могу найти никакой информации о том, как добавить параметры в раздел "SET" оператора UPDATE. Это код, который я превращаю в хранимую процедуру:

string sql = " update pay_control set payroll_type_cd = :payroll_type_cd, paystart_dt = :paystart_dt, payend_dt = :payend_dt, check_dt = :check_dt, ";
            sql += "eff_dt = :eff_dt, init_dt = :init_dt, close_dt = :close_dt, active = :active, completed = :completed,  release_pay = :release_pay where pay_control_id = :pay_control_id";

            List<UserInput> listUserInput = new List<UserInput>();

            listUserInput.Add(new UserInput(":payroll_type_cd", "System.Int64", userInputs.PayrollTypeCd.ToString()));
            listUserInput.Add(new UserInput(":pay_control_id", "System.Int64", userInputs.PayControlId.ToString()));
            listUserInput.Add(new UserInput(":paystart_dt", "System.DateTime", userInputs.PaystartDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":payend_dt", "System.DateTime", userInputs.PayendDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":check_dt", "System.DateTime", userInputs.CheckDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":eff_dt", "System.DateTime", userInputs.EffDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":init_dt", "System.DateTime", userInputs.InitDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":close_dt", "System.DateTime", userInputs.CloseDt.ToShortDateString()));
            listUserInput.Add(new UserInput(":active", "System.String", userInputs.Active));
            listUserInput.Add(new UserInput(":completed", "System.String", userInputs.Completed));
            listUserInput.Add(new UserInput(":release_pay", "System.String", userInputs.ReleasePay));

Я не планирую делать строки «listUserInput» частью хранимой процедуры, но я не могу понять, как передать информацию из «listUserInput» в хранимую процедуру. Какие-либо предложения? Спасибо


  • Как определяется тип UserInput? Как вы используете этот listUserInput? 09.12.2014

Ответы:


1

Я бы рекомендовал использовать MySqlCommand и параметризованные операторы, например:

MySql.Data.MySqlClient.MySqlCommand cmd;
cmd = new MySql.Data.MySqlClient.MySqlCommand();

cmd.CommandText = "UPDATE pay_control SET payroll_type_cd = @payroll_type_cd)";
cmd.Prepare();

cmd.Parameters.AddWithValue("@payroll_type_cd", 1);
09.12.2014
  • Итак, это почти то же самое, что я сделал бы в операторе where! Спасибо! 10.12.2014

  • 2

    Если нет причин сохранять этот класс UserInput, я бы вместо этого использовал непосредственно List<MySqlParameter>.

    List<MySqlParameter> listParams = new List<MySqlParameter>()
    {
       new MySqlParameter { ParameterName = ":payroll_type_cd", 
                            MySqlDbType=MySqlDbType.Int64, 
                            Value= Convert.ToInt64(userInputs.PayrollTypeCd)},
       new MySqlParameter { ParameterName = ":pay_control_id", 
                            MySqlDbType=MySqlDbType.Int64, 
                            Value = Convert.ToInt64(userInputs.PayControlId)},
       new MySqlParameter { ParameterName = ":paystart_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.PaystartDt},
       new MySqlParameter { ParameterName = ":payend_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.PayendDt},
       new MySqlParameter { ParameterName = ":check_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.CheckDt},
       new MySqlParameter { ParameterName = ":eff_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.EffDt},
       new MySqlParameter { ParameterName = ":init_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.InitDt},
       new MySqlParameter { ParameterName = ":close_dt", 
                            MySqlDbType = MySqlDbType.Date,
                            Value = userInputs.CloseDt},
       new MySqlParameter { ParameterName = ":active", 
                            MySqlDbType = MySqlDbType.VarChar,
                            Size = ???? datatable field size here ????
                            Value = userInputs.Active},
       new MySqlParameter { ParameterName = ":completed", 
                            MySqlDbType = MySqlDbType.VarChar,
                            Size = ???? datatable field size here ????
                            Value = userInputs.Completed},
       new MySqlParameter { ParameterName = ":release_pay", 
                            MySqlDbType = MySqlDbType.VarChar,
                            Size = ???? datatable field size here ????
                            Value = userInputs.ReleasePay}
    

    };

    И теперь вы можете создать MySqlCommand для получения этого списка параметров

       MySqlCommand cmd = new MySqlCommand("userProcName", connection);
       cmd.CommandType = CommandType.StoredProcedure;
       cmd.Parameters.AddRange(listParams.ToArray());
       cmd.ExecuteNonQuery();
    

    Обратите внимание, что с параметрами следует тщательно задавать тип данных, который передается хранимой процедуре. Таким образом, создание MySqlParameter по одному позволяет точно определить тип данных параметра.

    09.12.2014
    Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..