Версия для печати темы
Нажмите сюда для просмотра этой темы в оригинальном формате
Форум программистов > Разработка Windows Forms > Заполнение textBox из БД по значению ComboBox


Автор: 007700 20.12.2012, 09:32
Необходимо реализовать учебную среду. Реализовываем на C# с помощью Windows Forms. Существует база данных в Access. В ней два столбца: номер лабораторной и текст задачи. В одной лабораторной должно быть несколько задач. Следовательно, номера лабораторной будут повторяться. Итак, ComboBox заполняется номерами лаб из базы. Далее студент выбирает в ComboBox номер лабораторной. По номеру лабораторной в TextBox должен рэндомно выводиться текст одной из задач. Написали некоторый код, но он не работает. Есть подозрение, что здесь какая-то глобальная ошибка, нужна помощь.
Код

if (comboBox1.SelectedIndex >= 0)
            {
                string N = comboBox1.SelectedItem.ToString();
                 AutoCompleteStringCollection namesCollection = new AutoCompleteStringCollection();
                LabN = N;
                int d1 = dataGridView1.RowCount;
                int count = 0;
                for (int i = 0, j = 1; i < d1; i++)
                {
                    if (count < d1 - 1)
                    {
                        if (N == dataGridView1.Rows[i].Cells[j].Value.ToString())
                        {
                            OleDbConnection connection = new OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0; data source=Tasks.mdb");
                            OleDbCommand command = connection.CreateCommand();
                            connection.Open();
                            command.CommandText = "SELECT distinct [Task] FROM [Task] WHERE [LabN] = ? ORDER BY RAND() LIMIT 1";
                            command.Parameters.Add("LabN", OleDbType.Char).Value = comboBox1.SelectedText;
                            OleDbDataReader c = command.ExecuteReader();
                            while (c.Read())
                            {
                                namesCollection.Add( c["Task"].ToString());
                            }
                            count++;
                        }
                    }
                    else
                        MessageBox.Show("Ничего не выбрано");
                }
            }


Автор: 007700 20.12.2012, 17:07
Океей, половину вопроса можно снять. Итак, в нашей базе есть три столбца LabN, TaskN, Level. Все поля числовые. Нам нужно передавать в TextBox значение TaskN в виде текста. НО если меняешь тип данных на текстовый, то получаем следующую ошибку: несоответствие типов данных в выражении условия отбора! Помогите, пожалуйста.
Код

if (comboBox1.SelectedIndex >= 0)
            {

                string N = comboBox1.SelectedItem.ToString();
                OleDbConnection connection = new OleDbConnection("provider=Microsoft.Jet.OLEDB.4.0; data source=Lab.mdb");
                OleDbCommand command = connection.CreateCommand();
                connection.Open();
                command.CommandText = "SELECT TOP 1 [Zadanie] FROM [Lab] WHERE [Lab]=? AND [Level]=? ORDER BY Rnd([Zadanie])";
                command.Parameters.Add("Lab", OleDbType.Char).Value = N;
                command.Parameters.Add("Level", OleDbType.Char).Value = levelZ;
                string zadacha;
                zadacha = command.ExecuteReader().ToString();
                textBox1.Text = zadacha;     
           }

Powered by Invision Power Board (http://www.invisionboard.com)
© Invision Power Services (http://www.invisionpower.com)