Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
0 / 0 / 0
Регистрация: 30.03.2022
Сообщений: 41

Заполнение comboBox из другого comboBox

25.04.2022, 09:23. Показов 1365. Ответов 5

Студворк — интернет-сервис помощи студентам
У меня есть два комбобокса, нужно сделать зависимость второго от значений первого
Первый вызываю так:
C#
1
2
3
4
5
6
7
8
9
 using (OleDbConnection dbconn = new OleDbConnection(connStr))
            {
                dbconn.Open();
                DataTable tb1 = new DataTable();
                OleDbCommand dbcomm = new OleDbCommand(commStr, dbconn);
                OleDbDataAdapter da = new OleDbDataAdapter(dbcomm);
                da.Fill(tb1);
                comboBox1.DataSource = tb1;
                comboBox1.DisplayMember = "Площадь";
Пробовал добавлять второй
C#
1
2
3
4
5
6
DataTable tb2 = new DataTable();
                OleDbCommand dbcomm1 = new OleDbCommand($"SELECT id_площади FROM tempfield INNER JOIN temp2 on tempfield.площадь = temp2.{comboBox1.Text}", dbconn);
                OleDbDataAdapter da1 = new OleDbDataAdapter(dbcomm1);
                da1.Fill(tb2);
                comboBox2.DataSource = tb2;
                comboBox2.DisplayMember = "id_площади";
Но вызывается ошибка на 4 строку
Может кто знает как это должно работать?
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
25.04.2022, 09:23
Ответы с готовыми решениями:

Заполнение comboBox из другой формы
Всем доброго времени суток. Возникла проблема. Есть метод в форме1 с помощью которого заполняется ComboBox public void...

Заполнение ComboBox в соответствии со значением другого ComboBox
Значицца имеются, например, две таблички: Дисциплина (Математика, История, Язык, Информатика, и т.д.) и Работа (Модуль 1, Модуль 2,...

Как связать два ComboBox так, чтобы при заполнении одного ComboBox он соответствовал со значением другого ComboBox
Здравствуйте. Помогите мне, пожалуйста, сделать это через SQL запрос! У меня есть одна таблица - Subjects, которая содержит следующие...

5
 Аватар для iLinks
800 / 458 / 237
Регистрация: 03.01.2017
Сообщений: 1,339
25.04.2022, 10:20
Цитата Сообщение от Kitagawa Посмотреть сообщение
вызывается ошибка на 4 строку
Какая ошибка?
Заполнение 2го комбобокса происходит в событии нового выбора 1го комбобокса?
0
0 / 0 / 0
Регистрация: 30.03.2022
Сообщений: 41
25.04.2022, 10:47  [ТС]
Цитата Сообщение от iLinks Посмотреть сообщение
Какая ошибка?
"Invalid column name 'System'."

Цитата Сообщение от iLinks Посмотреть сообщение
Заполнение 2го комбобокса происходит в событии нового выбора 1го комбобокса?
Да, в comboBox1_SelectedIndexChanged
0
 Аватар для iLinks
800 / 458 / 237
Регистрация: 03.01.2017
Сообщений: 1,339
25.04.2022, 11:28
Лучший ответ Сообщение было отмечено Kitagawa как решение

Решение

Цитата Сообщение от Kitagawa Посмотреть сообщение
OleDbCommand dbcomm1 = new OleDbCommand($"SELECT id_площади FROM tempfield INNER JOIN temp2 on tempfield.площадь = temp2.'{comboBox1.Text}'", dbconn);
Попробуйте добавить одинарные кавычки в запрос, где вставляете переменную.
C#
1
OleDbCommand dbcomm1 = new OleDbCommand($"SELECT id_площади FROM tempfield INNER JOIN temp2 on tempfield.площадь = temp2.'{comboBox1.Text}'", dbconn);
0
0 / 0 / 0
Регистрация: 30.03.2022
Сообщений: 41
25.04.2022, 12:00  [ТС]
Цитата Сообщение от iLinks Посмотреть сообщение
Попробуйте добавить одинарные кавычки в запрос
Работает
А не подскажешь, я хочу во второй комбобокс вывести список из таблицы которая связана с таблицей из первого комбобокса, вывожу на основе запроса с подзапросом и получаю "System.Data.DataRowView" Как от этого избавиться ?

Добавлено через 5 минут
Попробовал сделать так
C#
1
2
3
4
5
 OleDbDataReader reader = dbcomm2.ExecuteReader();
                while (reader.Read())
                {
                    comboBox2.Items.Add(reader["площадь"].ToString());
                }
Но он выводит просто список, не зависящий от первого комбобокса

Добавлено через 3 минуты
Точнее он зависит от первого комбобокса, но лишь первый выбор, дальше не меняется
0
0 / 0 / 0
Регистрация: 30.03.2022
Сообщений: 41
26.04.2022, 06:39  [ТС]
Цитата Сообщение от Kitagawa Посмотреть сообщение
дальше не меняется
Кому пригодится, добавил перед циклом
C#
1
 comboBox2.Items.Clear();
И всё работает нормально
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
26.04.2022, 06:39
Помогаю со студенческими работами здесь

Как при выборе значения в combobox изменить значение другого combobox
Добрый день. Есть допустим бд с таблицей в которой есть name И number. Как сделать так, чтобы при выборе имени в комбобоксе во втором...

Combobox значение которого меняется в зависимости от выбора другого Combobox'a
Добрый день, у меня есть задача, я с реализацией трудновато. суть такова, есть combobox, в котором на выбор есть несколько пунктов, и при...

Как сделать combobox зависимым полем от другого combobox?
Как сделать combobox зависимым от того, что выше него. Допустим я выбираю тип товара (продовольственный или непродовольственный) и в...

Как сделать ComboBox зависимым от другого ComboBox
Имеются два combobox'а в обоих одни и теже данные города отправки и прибытия как сделать их зависимыми друг от друга Допустим если в...

Заполнение ComboBox из БД в зависимости от значения в другом ComboBox
Помогите пожалуйста сделал базу в sql server и привязал ее к visual studia но возникла проблема как сделать так что бы при выборе в ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru