Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 0
Регистрация: 21.03.2018
Сообщений: 24

Добавление ComboboxColumn к DGV у которого есть DataSource

13.05.2019, 18:10. Показов 897. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вопрос такой:
Из SQL получаю DataSet - (DS) с несколькими DataTable - (Tables), где DS.Tables[0] - основная таблица с данными, а DS.Tables[1] - набор значений для Items DataGridViewComboBoxColumn.

Если я устанавливаю для DataGridView DataSource как Tables[0], могу ли я потом изменить тип одного из столбцов до DataGridViewComboBoxColumn, добавив Items из доп таблиц и установить выбранный Item равный тексту из первой таблицы?

Простой пример таблиц на входе


Т.е в резульатате в dgv должны быть 2 колонки:
1 тип string в которой находятся имена
2 тип ComboBox column, у которой в Items находятся список из Tables[1], а выбрано значение которое было указано в Tables[0]
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
13.05.2019, 18:10
Ответы с готовыми решениями:

Отображение содержимого DGV при смене DataSource
Уважаемые форумчане, ситуация такая - есть DGV и Combobox, при изменении значения которого меняется и datasource. код ниже string cmbbx...

Как обновить Datasource и отобразить изменения в DGV
Здравствуйте! помогите разобраться.. Подключен к БД АКСЕСС таблица простая имеет всего три колонки. При нажатии на кнопку должно...

Добавление несколько значений в datasource
Здравствуйте. Для подключении к базе данных MS Access использую ADOConnection. Присутствует DataSource, adoquery. в датасоурс есть 4 поля,...

3
0 / 0 / 0
Регистрация: 21.03.2018
Сообщений: 24
14.05.2019, 09:15  [ТС]
Неужели нет решений?
0
78 / 67 / 13
Регистрация: 04.10.2018
Сообщений: 330
14.05.2019, 09:25
Если я вас правильно понял. То это то что вам нужно.


C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
 public PlaceNameGraphics(DataTable TransitionDT)
        {
            InitializeComponent();
            _TransitionDT.Columns.Add("PnumTel");
            _TransitionDT.Columns.Add("TYPETel");
            _TransitionDT.Columns.Add("ParametrVivoda");           
            string _Pnum, _Tip;
            ds = new DataSet();
            dataGridViewSql.Columns.Add("col1", "Prodject номер");
            dataGridViewSql.Columns.Add("col2", "Тип");
            comboCol.Name = "cmbColumn";
            comboCol.HeaderText = "Параметр обработки";
            comboCol.DefaultCellStyle.BackColor = Color.White;
            dataGridViewSql.Columns.Add(comboCol);
            for (int i = 0; i < TransitionDT.Rows.Count; i++)
            {
                ParametrVivodaList.Clear();
                Proverka.Add(new OutputParameter(TransitionDT.Rows[i][1]));
                ParametrVivodaList.AddRange(Proverka[i].ParametrVivoda);
                _Pnum = TransitionDT.Rows[i][0].ToString();
                _Tip = TransitionDT.Rows[i][1].ToString();                
                Index.Add(i);
 
                DataTable table = new DataTable("table" + i);
                table.Columns.Add("column1", typeof(string));
                foreach (string item in ParametrVivodaList)
                    table.Rows.Add(item.ToString());
                ds.Tables.Add(table);
                CreateCustomComboBoxDataSouce(i, _Pnum, _Tip, table);
                dataGridViewSql.Columns[2].Width = 400;
                dataGridViewSql.Columns[1].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
               dataGridViewSql.Columns[0].AutoSizeMode = DataGridViewAutoSizeColumnMode.AllCells;
            }
        }

C#
1
2
3
4
5
6
7
8
   private void CreateCustomComboBoxDataSouce(int row, string texst, string Tip, DataTable table)
        {
            dataGridViewSql.Rows.Add(texst.ToString(), Tip.ToString());
            DataGridViewComboBoxCell comboCell = dataGridViewSql[2, row] as DataGridViewComboBoxCell;
            comboCell.DataSource = new BindingSource(table, null);
            comboCell.DisplayMember = "column1";
            comboCell.ValueMember = "column1";
        }
0
0 / 0 / 0
Регистрация: 21.03.2018
Сообщений: 24
14.05.2019, 10:00  [ТС]
Не совсем, т.к в вашем решении нет привязки DGV к DataSource, меня больше интересовало решение через него, а именно как в DataTable, которое будет выступать DataSource для DGV создать колонку типа CoboBoxColumn ... Просто в дальнейшем хочу использовать готовый автофильтр на этом DGV, а он могет только если данные подаются из DataSource
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
14.05.2019, 10:00
Помогаю со студенческими работами здесь

Добавление записи в DGV (Значения вводятся на второй форме)
Здраствуйте уважаемые форумчане. Не знаю как сделать добавление записи в datagridview1. Значения вводятся на второй форме. Помогите...

Перенос данных из одного DGV в другой DGV
Нужно перенести данные из одного dgv в другой(в идеале ещё прибавить к столбцам выбранные значения из текстбокса). DGV-хи находятся на...

Открытие в файла в DGV и сохранение из DGV в файл
Вот 2 кода Сохраняет нормально, но открыть потом не получается как будто не дочитывает и что, непойму Сохраняю string SaveString =...

ComboBoxColumn выдает ошибку
Здравствуйте. Уже больше часа мучаюсь с одной проблемой - заполняю ComboBoxColumn из БД, выбираю элемент и программа выдает ошибку...

DataGrid ComboboxColumn не принимает значение
Всем привет, мучаюсь с DataGrid в WPF. В ДатаГрид я программно, динамически добавляю колонки. Если колонка - ссылка на таблицу в БД, то...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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 и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
Управление камерой с помощью скрипта OrbitControls.js на Three.js: Вращение, зум и панорамирование
8Observer8 05.03.2026
Содержание блога Финальная демка в браузере работает на Desktop и мобильных браузерах. Итоговый код: orbit-controls-threejs-js. zip. Сканируйте QR-код на мобильном. Вращайте камеру одним пальцем,. . .
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru