Практическое руководство. Связывание элемента управления ComboBox или ListBox с данными в Windows Forms
Вы можете привязать ComboBox и ListBox к данным для выполнения таких задач, как просмотр данных в базе данных, ввод новых данных или изменение существующих данных.
Привязка элемента управления ComboBox или ListBox
- Присвойте свойству DataSource объект источника данных. Возможные источники данных включают привязку BindingSource к данным, таблице данных, представлению данных, набору данных, диспетчеру представлений данных, массиву или любому классу, реализующему интерфейс IList. Дополнительные сведения см. в разделе Источники данных, поддерживаемые Windows Forms.
- Если выполняется привязка к таблице, присвойте свойству DisplayMember имя столбца в источнике данных. — или — При привязке к IList, задайте для элемента отображения общедоступное свойство типа в списке.
Private Sub BindComboBox() ComboBox1.DataSource = DataSet1.Tables("Suppliers") ComboBox1.DisplayMember = "ProductName" End Sub
private void BindComboBox()
Примечание. При привязке к источнику данных, который не реализует интерфейс IBindingList, например ArrayList, данные привязанного элемента управления не будут обновляться при обновлении источника данных. Например, если поле со списком привязано к ArrayList, а данные добавляются в ArrayList, эти новые элементы не будут отображаться в поле со списком. Однако можно принудительно обновить поле со списком, вызвав методы SuspendBinding и ResumeBinding в экземпляре класса BindingContext, к которому привязан элемент управления.
См. также
- ComboBox
- ListBox
- Привязка данных Windows Forms
- Привязка данных и Windows Forms
- Создание списка для выбора элементов в Windows Forms
Совместная работа с нами на GitHub
Источник этого содержимого можно найти на GitHub, где также можно создавать и просматривать проблемы и запросы на вытягивание. Дополнительные сведения см. в нашем руководстве для участников.
Как заполнить combobox из базы данных c
Кроме прямого добавления элементов в коллекцию Items компонентов ListBox и ComboBox мы также можем использовать механизм привязки данных.
Привязка данных в ListBox и ComboBox реализуется с помощью следующих свойств:
- DataSource : источник данных — какой-нибудь массив или коллекция объектов
- DisplayMember : свойство объекта, которое будет использоваться для отображения в ListBox / ComboBox
- ValueMember : свойство объекта, которое будет использоваться в качестве его значения
public partial class Form1 : Form < public Form1() < InitializeComponent(); Listphones = new List < new Phone < Name="Samsung Galaxy Ace 2", Year=2012>, new Phone < Name="Samsung Galaxy S4", Year=2013>, new Phone < Name="iPhone 6", Year=2014>, new Phone < Name="Microsoft Lumia 435", Year=2015>, new Phone < Name="Xiaomi Mi 5", Year=2015>>; listBox1.DataSource = phones; listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id"; listBox1.SelectedIndexChanged += listBox1_SelectedIndexChanged; > void listBox1_SelectedIndexChanged(object sender, EventArgs e) < // получаем id выделенного объекта int // получаем весь выделенный объект Phone phone = (Phone)listBox1.SelectedItem; MessageBox.Show(id.ToString() + ". " + phone.Name); >> class Phone < public int Id < get; set; >public string Name < get; set; >public int Year < get; set; >>
Итак, на форме у нас есть список ListBox с именем listBox1. В коде имеется класс Phone с тремя свойствами, объекты которого мы хотим выводить в список. В отличие от предыдущих тем эта задача сложнее, так как раньше мы выводили обычные строки, тут же у нас сложные объекты.
Для вывода используем механизм привязки. Сначала устанавливаем список телефонов в качестве источника данных:
listBox1.DataSource = phones;
Затем устанавливаем в качестве отображаемого свойства свойство Name класса Phone, а в качестве свойства значения — свойство Id:
listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id";
Значение отображаемого свойства мы затем увидим в списке. Оно будет представлять каждый отдельный объект Phone.
С помощью же свойства значения, которым является свойство Id, мы можем упростить работу с источником данных. В данном случае оно не играет большой роли. Но если бы мы использовали в качестве источника данных некоторый набор объектов из базы данных, то с помощью id нам было проще удалять, обновлять и взаимодействовать с базой данных.
И теперь если мы выделим какой-то объект, то свойство SelectedItem элементы ListBox будет содержать объект Phone, у которого мы можем получить значения свойств:
Phone phone = (Phone)listBox1.SelectedItem; string name = phone.Name;
А выделенное значение, то есть значение свойства Id выделенного телефона, будет находиться в свойстве SelectedValue .
И если мы запустим приложение, то увидим все отображаемые телефоны:

Все то же самое характерно и для элемента ComboBox. Пусть кроме ListBoxa на форме есть ComboBox:
public partial class Form1 : Form < public Form1() < InitializeComponent(); Listphones = new List < new Phone < Name="Samsung Galaxy Ace 2", Year=2012>, new Phone < Name="Samsung Galaxy S4", Year=2013>, new Phone < Name="iPhone 6", Year=2014>, new Phone < Name="Microsoft Lumia 435", Year=2015>, new Phone < Name="Xiaomi Mi 5", Year=2015>>; comboBox1.DataSource = phones; comboBox1.DisplayMember = "Name"; comboBox1.ValueMember = "Id"; comboBox1.SelectedIndexChanged += comboBox1_SelectedIndexChanged; listBox1.DisplayMember = "Name"; listBox1.ValueMember = "Id"; > void comboBox1_SelectedIndexChanged(object sender, EventArgs e) < Phone phone = (Phone)comboBox1.SelectedItem; listBox1.Items.Add(phone); >> class Phone < public int Id < get; set; >public string Name < get; set; >public int Year < get; set; >>
Здесь также для комбобокса устанавливается привязка, а также отображаемое свойство и свойство значения. Кроме того, здесь обрабатывается событие выбора элемента в комбобоксе так, чтобы выбранный элемент попадал в ListBox.

В отличие от ListBoxa ComboBox имеет три свойства для обработки выделенного объекта:
- SelectedItem : выбранный элемент
- SelectedValue : значение свойства значения, в данном случае свойство Id
- SelectedText : значение свойства отображение, в данном случае свойство Name класса Phone
Заполнить Combobox данными из таблицы БД, в зависимости от значения выбранного в другом Combobox’е

Мне нужна помощь с решением небольшой задачи. Сам уже много чего перепробовал, но не выходит( Пишу программу для курсового (для управляющего отелем). У меня есть таблица Rooms с полями room_id и room_type, мне нужно, чтобы при выборе типа комнаты для резервирования в combobox с room_id подставлялись все id комнат из таблицы Rooms, которые имеют данный тип (Single, к примеру). Надеюсь понятно объяснил. Ниже код загрузки данных в комбобоксы(из form_load).
// loading data to combobox3 DataTable Rooms = new DataTable(); using (SqlConnection coon = new SqlConnection(conString)) < SqlCommand cmd = new SqlCommand(); cmd.Connection = coon; cmd.CommandText = "select room_type from Rooms where reservation_id = 0"; SqlDataAdapter adapter = new SqlDataAdapter(cmd); adapter.Fill(Rooms); >for (int i = 0; i < Rooms.Rows.Count; i++) < comboBox3.Items.Add(Rooms.Rows[i]["room_type"]); >// loading data to combobox2 using (SqlConnection coon = new SqlConnection(conString)) < SqlCommand cmd = new SqlCommand(); cmd.Connection = coon; cmd.CommandText = "select froom_id from Rooms where reservation_id = 0" SqlDataAdapter adapter = new SqlDataAdapter(cmd); adapter.Fill(Rooms); >for (int i = 0; i
Пробовал делать как-то так, но чтобы данные в комбобоксе с room_id обновились нужно обновить и форму, а после этого сбрасывается значение в комбобоксе с room_type пробовал сохранять его и подставлять после загрузки формы опять, но ничего так и не получилось. Может кто-нибудь подскажет, как это сделать?
cmd.CommandText = "select froom_id from Rooms where reservation_id = 0 AND room_type = " + "'" + comboBox3.Text + "'";
Как заполнить combobox из базы данных c
Регистрация: 19.07.2013
Сообщений: 1
заполнение combobox из бд
Всем добрый день!
Недавно начала изучать с#, и вот возник вопрос. Надеюсь, вы мне поможете разобраться с этим )
Моя задача, отфильтровать датагридвью с помощью выпадающего списка. Т.е. я выбираю значение в комбобоксе, а информация по этому значению вылазит в датагрид-е.
Проблема в том, что я не до конца понимаю, как заполнить комбобокс из базы данных.. знаю, что надо использовать DataSource, DisplayMember и ValueMember. А куда, что и как.. не очень понятно)
Особенно , что касается датаадаптера и дата тэйбл)
Была бы очень признательна, если бы вы помогли мне разобраться, а в особенности за пример кода)
| Kira_Polyakova |
| Посмотреть профиль |
| Найти ещё сообщения от Kira_Polyakova |
| Похожие темы | ||||
| Тема | Автор | Раздел | Ответов | Последнее сообщение |
| заполнение textbox по данным из combobox | Владимир2222 | Microsoft Office Excel | 8 | 02.04.2013 08:20 |
| заполнение combobox с другого листа | caught.let | Microsoft Office Excel | 3 | 14.03.2012 21:06 |
| Заполнение combobox. | NicBor | Microsoft Office Word | 4 | 12.11.2010 14:05 |
| ComboBox и заполнение базы данных InterBase | anechka3107 | БД в Delphi | 2 | 26.05.2010 00:42 |
| Заполнение ComboBox датами | segail | Microsoft Office Excel | 9 | 12.01.2010 21:47 |