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

DataGridView. Столбец подстановки из родительской таблицы.

26.05.2009, 11:18. Показов 7707. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет.
Хочу чтобы в DataGridView (связанного с dataset), отображающего таблицу условно №1, добавить столбец из связанной справочной таблицы №2.
Например, №1:
  • ID
  • Shifr
  • ID_Name
N2:
  • ID_Name
  • Name
Вот, чтобы в DataGridView и появился столбец Name из второй таблицы.

Пока пытаюсь это сделать грубо, добавив новый столбец в DataGridView, и после заполнения его связанными данными, перебираю все строки и дописываю значение в этот столбец.
Вроде каряво. нужно следить за обновлениями DataGridView.

Можно ли это сделать через bindingSource или еще как?
Спасибо.
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
26.05.2009, 11:18
Ответы с готовыми решениями:

Создать столбец подстановки в dataGridView
Мне надо создать столбец подстановки в моем приложении, таблицы связаны внешним ключом. Говорят, в Microsoft SQL Server нет такой...

Как сделать так, чтобы в одном DataGridView раскрывались данные из другой таблицы, т.к. один столбец является ссылкой
Как сделать так, чтобы раскрывались данные из другой таблицы, т.к. в первой таблице один столбец ялвяется ссылочным на другую таблицу, дак...

Заполнение TextBox на дочерней форме из DataGridView на родительской
динамически создается БД(SQLite), динамически создается dataGridView. во время работы программы из dataGridView надо заполнить несколько...

12
Комбайнёр
 Аватар для MAcK
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
26.05.2009, 23:00
Скинь саму БД, помогу, а то самому создавать лень
0
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
27.05.2009, 02:51
Почему бы в DataSet не создать таблицу, которая сразу будет отдавать нужные поля?
0
1 / 1 / 0
Регистрация: 16.04.2009
Сообщений: 23
27.05.2009, 09:21  [ТС]
Думаю базу скидывать не к чему, она не маленькая, и только запутает вас.
Грин, спасибо, попробую так сделать, сам об этом не подумал, опыту маловато.
0
ralfeus
14.06.2009, 17:21
Цитата Сообщение от Green Посмотреть сообщение
Почему бы в DataSet не создать таблицу, которая сразу будет отдавать нужные поля?
А как "идеологически" правильнее - создавать таблицу в DataSet с нужными полями или все-таки связывать таблицы?
Комбайнёр
 Аватар для MAcK
1606 / 704 / 77
Регистрация: 27.05.2008
Сообщений: 2,535
14.06.2009, 20:46
Вообще прощё создать SQL запрос и вывести результат в грид
0
 Аватар для nio
6050 / 3460 / 336
Регистрация: 14.06.2009
Сообщений: 8,136
Записей в блоге: 2
15.06.2009, 00:58
в dataset нужно создать новый tableadapter с представлением или Selectом, выбирающим нужные столбцы, и с ним связать datagridview
0
1923 / 428 / 41
Регистрация: 12.07.2007
Сообщений: 2,062
15.06.2009, 02:20
Цитата Сообщение от ralfeus Посмотреть сообщение
А как "идеологически" правильнее - создавать таблицу в DataSet с нужными полями или все-таки связывать таблицы?
Все зависит от поставленной задачи, от того что и как вы будете делать с данными.
0
0 / 0 / 1
Регистрация: 04.12.2010
Сообщений: 14
16.05.2011, 11:40
А если задание состоит именно в том чтобы заполнять этот столбец в коде. Делаю по примеру в лабе

C#
1
2
3
for (int i = 0; i < dataGridView2.RowCount; i++)
                dataGridView2["loName", i].Value =
                  bdDataSet.LicOrg.FindByidLicOrg((int) dataGridView2["LicOrg", i].Value).loName;
Выдает следующую ошибку (VS2008)
На втором скрине образец из лабораторки
В чем может быть причина?
Миниатюры
DataGridView. Столбец подстановки из родительской таблицы.   DataGridView. Столбец подстановки из родительской таблицы.  
0
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
16.05.2011, 13:08
Цитата Сообщение от Vildar Посмотреть сообщение
Привет.
Хочу чтобы в DataGridView (связанного с dataset), отображающего таблицу условно №1, добавить столбец из связанной справочной таблицы №2.
Например, №1:
  • ID
  • Shifr
  • ID_Name
N2:
  • ID_Name
  • Name
Вот, чтобы в DataGridView и появился столбец Name из второй таблицы.

Пока пытаюсь это сделать грубо, добавив новый столбец в DataGridView, и после заполнения его связанными данными, перебираю все строки и дописываю значение в этот столбец.
Вроде каряво. нужно следить за обновлениями DataGridView.

Можно ли это сделать через bindingSource или еще как?
Спасибо.
Для таких случаев есть свойство Expression в колонке ДатаТейбл ДатаСета.
Прописываешь в колонке ID_Name первой таблицы в свойстве Expression следующее Parent.Name и получаешь в ДатаГридВью вместо индекса значение.

Добавлено через 6 минут
Цитата Сообщение от sinbad7 Посмотреть сообщение
А если задание состоит именно в том чтобы заполнять этот столбец в коде. Делаю по примеру в лабе

C#
1
2
3
for (int i = 0; i < dataGridView2.RowCount; i++)
                dataGridView2["loName", i].Value =
                  bdDataSet.LicOrg.FindByidLicOrg((int) dataGridView2["LicOrg", i].Value).loName;
Выдает следующую ошибку (VS2008)
На втором скрине образец из лабораторки
В чем может быть причина?
Здесь два варианта может быть.
Либо dataGridView2["loName", i].Value значение пустое, либо FindByidLicOrg() не находит и также возвращает пустое значение.
1
0 / 0 / 1
Регистрация: 04.12.2010
Сообщений: 14
16.05.2011, 13:56
Цитата Сообщение от Nukutu Посмотреть сообщение
Здесь два варианта может быть.
Либо dataGridView2["loName", i].Value значение пустое, либо FindByidLicOrg() не находит и также возвращает пустое значение.
Нет, не в этом дело, Value не пустое, FindBy, соответственно, чего-то должен находить в таблице по этому коду
Изображения
 
0
181 / 107 / 13
Регистрация: 22.03.2010
Сообщений: 456
16.05.2011, 16:03
Цитата Сообщение от sinbad7 Посмотреть сообщение
Нет, не в этом дело, Value не пустое, FindBy, соответственно, чего-то должен находить в таблице по этому коду
Тогда проверь в дебаге еще bdDataSet и LicOrg.

Ошибка четко указывает, что где-то пустой объект, который используешь.
0
0 / 0 / 1
Регистрация: 04.12.2010
Сообщений: 14
16.05.2011, 17:27
нашел ошибку, надо было tableadapter сделать для licorg
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
16.05.2011, 17:27
Помогаю со студенческими работами здесь

В середину таблицы DataGridView добавить столбец
Подскажите, пожалуйста! Мне надо в середину(!!!именно в середину!!!) таблицы dataGridView добавить столбец, скажите, существует ли...

Подставить автоматически данные из ComboBox в столбец DatagridView таблицы при создании новой записи в строке
Здравствуйте! подскажите пожалуйста как реализовать автоматическую подстановку данных из ComboBox в нужный столбец DatagridView, таблицы...

Столбец подстановки, но не простой...
Ситуация следующая: на форме есть поле со списком(источник данных, как в 'Борее'). Нужно чтобы при отсутствии в списке нужного елемента, пр...

Как программно изменить столбец подстановки?
Как программно изменить столбец подстановки? Не лучше ли для этого использовать запросы?

Передача данных DataGridView из родительской формы в дочернюю
Всем привет! В общем у меня 2 формы в первой есть dgv в котором 5 колонок одни из них id и name а так же на форме есть кнопка по нажатию на...


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

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru