@White_Bambie

Как получить значение Checkedlistbox из базы данных MySQL?

На форме имеется Checkedlistbox. Пользователь выбирает из списка элементы и данные загружаются в БД.
if (cl_Additional.CheckedItems.Count > 0)
{
  for (int i = 0; i < cl_Additional.CheckedItems.Count; i++)
  {
    if (additional == "")
    {
      additional = cl_Additional.CheckedItems[i].ToString();                   
    }
    else
    {
    additional += ", " + cl_Additional.CheckedItems[i].ToString();
    }
  }
}
MySqlConnection con = new MySqlConnection(AppSetting.ConnectonString());

con.Open();

MySqlCommand cmd;
cmd = con.CreateCommand();
cmd.CommandText = "INSERT INTO patients(Additional) VALUES(@Additional)";
cmd.Parameters.AddWithValue("@Additional", additional);

cmd.ExecuteNonQuery();
con.Close();


Как извлечь данные из БД и добавить их Checkedlistbox [cl_Additional]?
  • Вопрос задан
  • 267 просмотров
Решения вопроса 1
@White_Bambie Автор вопроса
Сделал вот так:
MySqlConnection con = new MySqlConnection(AppSetting.ConnectonString());
            MySqlCommand cmd;
            cmd = con.CreateCommand();
            cmd.CommandText = "SELECT * FROM patients WHERE id='"+ MyListBox.SelectedValue + "';";

            try
            {
                con.Open();

                MySqlDataReader sdr = cmd.ExecuteReader();
                
                string[] sAdditional = new string[] { };
                char[] mychars = { ',' };

                // Чистим чекбоксы
                while (cl_Additional.CheckedItems.Count > 0)
                {
                    cl_Additional.SetItemChecked(cl_Additional.CheckedIndices[0], false);
                }

                // Загружаем данные
                while (sdr.Read())
                {           
                    sAdditional = sdr.GetString("Additional").Split(mychars);
                }

                // Заполняем список чекбоксов
                int length = sAdditional.Length;
                for (int i = 0; i < length - 1; i++)
                {
                    string fetr = sAdditional[i];
                    for (int j = 0; j <= cl_Additional.Items.Count - 1; j++)
                    {
                        if (cl_Additional.Items[j].ToString() == sAdditional[i])
                        {
                            cl_Additional.SetItemChecked(j, true);
                            break;
                        }
                    }
                }

                con.Close();
            }
            catch (Exception)
            {
                MessageBox.Show("Подключение к серверу отсутствует");
            }
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы