Как изменить текст метки в зависимости от элемента, выбранного в поле со списком, который заполняется с помощью SQLite? - PullRequest
0 голосов
/ 09 апреля 2019

У меня есть кнопка, которая создает 6 элементов управления для столбцов TableLayoutPanel, 6 столбцов: номер заказа, название продукта ( поле со списком ), текущее количество ( метка ), Количество купленных, новое количество и строка удаления.

Поле со списком заполняется с помощью SQLite.Для таблицы вариантов у меня есть 7 столбцов: [Название продукта], Имя, [Серийный номер], [Склад в наличии], [Продать до].

Как сделать так, чтобы надписи под«Текущее количество» изменяется в зависимости от [На складе в наличии] выбранного элемента в поле со списком?

В моем текущем коде ошибка «Индекс находился за пределами массива» отображается каждый раз, когда я выбираюв поле со списком.

Код для создания динамического поля со списком:

ComboBox cboItemName = new ComboBox
            {
                Name = "cboItemName" + rowIndex,
                Dock = DockStyle.Fill,
                DropDownStyle = ComboBoxStyle.DropDownList
            };
            cboItemName.SelectedIndexChanged += new EventHandler(cboItemName_SelectedIndexChanged);
            tblOrders.Controls.Add(FillComboBox(cboItemName));

Код для обработчика события поля со списком:

 void cboItemName_SelectedIndexChanged(object sender, EventArgs e)
        {
            var cbo = (ComboBox)sender;
            string name = cbo.Name;
            string splittedString = new String(name.Where(Char.IsDigit).ToArray());;

            string labelName = "lblCurrentQuantity" + splittedString;
            string selectedIndex = cbo.SelectedIndex.ToString();
            string selectedItem = cbo.SelectedItem.ToString();

            Label tbx = tblOrders.Controls.Find(labelName, true).FirstOrDefault() as Label;
            EditLabelCurrentQuantity(tbx, selectedItem);
        }

И, наконец,код для изменения текста этикетки:

private void EditLabelCurrentQuantity(Label label, string itemSelected)
        {
            auth = new Authentication();
            auth.getConnection();

            try
            {
                using (SQLiteConnection con = new SQLiteConnection(auth.connectionString))
                {

                    con.Open();

                    SQLiteCommand cmd = new SQLiteCommand();

                    cmd.CommandText = @"SELECT [Stock On Hand] FROM Variants WHERE Name='" + itemSelected + "'";
                    cmd.Connection = con;


                    SQLiteDataReader reader = cmd.ExecuteReader();
                    while (reader.Read())
                    {
                        string name = Convert.ToString(reader["[Stock On Hand]"]);
                    }

                    con.Close();
                }
            }
            catch (Exception ex)
            {
                MessageBox.Show(ex.Message, "Error", MessageBoxButtons.OK, MessageBoxIcon.Error);
            }
        }

1 Ответ

0 голосов
/ 10 апреля 2019

Я наконец понял, что если кто-то когда-нибудь сталкивался с моим плохим дизайном, я исправил это, добавив:

string name = Convert.ToString(reader[0]);
labelCategory.Text = name;

в:

SQLiteDataReader reader = cmd.ExecuteReader();
while (reader.Read())
{
    string name = Convert.ToString(reader["[Stock On Hand]"]);
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...