|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
Обращение к DataGridView в другой форме16.10.2010, 07:34. Показов 9136. Ответов 30
Метки нет (Все метки)
Доброе утро.
Проблема следующая есть 2 формы в каждой из них есть таблица (разные) одной базы данных. Но в каждой форме обе таблицы имеют номер DataGridView1. Проблема в том что мне при загрузке формы 1 необходимо получить данные таблицы, находящейся в форме 2. Как это сделать подскажите пожалуйста.
0
|
|
| 16.10.2010, 07:34 | |
|
Ответы с готовыми решениями:
30
Обращение к другой форме
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 16.10.2010, 12:43 | |
|
Ответы на 7 самых частых вопросов по WinForms
передать ссылку на гридвью через конструктор, например или ссылку на дататэйбл этого гридвью
0
|
|
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 19:55 [ТС] | |
|
Чтобы передать данный между двумя формами надо чтобы обе были открыты а я не предполагаю открывать эту форму ни до ни в момент передачи
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 16.10.2010, 20:11 | |
|
какое-то тут у нас недопонимание.
если у вас форма не создана, то и передавать из нее нечего. как вы все таки мыслите делать эту передачу? з.ы. если данные глобальные - то наличие форм для передачи необязательно
0
|
|
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 20:14 [ТС] | |
|
Форма создана. Но не открывалась и не предполагает открытие на момент передачи. Либо возможен вариант открытия но в режиме в котором она не будет показываться (если такой есть).
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 16.10.2010, 20:21 | |
|
кажись поняла.у вас что-то типа загрузки данных в onLoad 2ой формы, но при этом вызвалась она вовсе не из 1ой формы, но данные оттуда взять должна?
если так, то 1)можно сделать источник данных (dataset?) 1ой формы публичным и в любое время обращаться к нему из 2ой формы 2) в каком-то основном методе вашей программы сделать заливку датасетов из бд, а потом уж тиражировать их и в 1, и во 2 формы, через конструкторы или через публичность, как больше нравится
1
|
|
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 20:33 [ТС] | |
|
немножко не так но проблема именно такая. А попроще ничего нету ? а то из сказанного я мало понял. Меня устроит загрузка формы 2 при запуске формы 1, лишь бы её не было видно. что-нибудь вместо showDialog есть такое?
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 16.10.2010, 20:53 | |
|
да тут ничего сложного в общем-то)может,я просто коряво объяснила?
не показывать форму 1, конечно, можно, но зачем?код тогда,наверно, будет выглядеть примерно так: где-то вы вызываете конструктор 1, он создает форму 1, дальше в этом же конструкторе или по таймеру будет вызван конструтор 2 и ему переданы данные из 1 (лучше в виде dataset или datatable). где-то в любом месте вызываете form1.Hide(). но все равно не могу понять,зачем так делать?может,я чего не понимаю?у вас в форме 1 что-то делается с данными такого, чего нельзя бы было сделать вне ее?она просто получается ненужным посредником.мне кажется, тут как-то надо логику работы с данными пересмотреть может?
0
|
|
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 21:07 [ТС] | |
|
давайте я все подробно разъясню, может я выбрал корявый способ:
Есть "Форма 1" на ней есть comboBox который содержит допустим 3 записи. Этих 3-х записей может быть недостаточно и пользователь захотел добавить четвертую для этого он открывает "форма 2" в которой имеется таблица базы данных которую он поплняет четвертой строкой и сораняет изменения. В результате в comboBox в "Форме 1" становится 4 записи. И надо чтобы в последующие разы, когда он заходит в "Форму 1" в comboBox уже было 4 записи а не 3. Для этого я и хочу чтобы при запуске " Формы 1" происходило считывание базы данных таблицы, подключенной к "форме 2". Есть ещё 1 корявый сопосб который я рассматриваю из-за своего невежества=) Добавить таблицу БД которая находится в вызываемой "Форме 2" в "Форму 1" и сделать её скрытой чтобы она все время там висела и при запуске программы считывать из неё данные в comboBox.
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
||||||
| 16.10.2010, 21:31 | ||||||
|
ну тут возможны варианты и различные подходы, конечно
вариант 1:при старте проги слить все инфо в датасет,в разные таблицы. далее в программе уже работать только с датасетом (изменять, добавлять, удалять).а потом при завершении работы занести изменения в базу (не всегда хорошо, т.к. кнопку ресет еще никто не отменял, а изменения нифига не занесутся) вариант 2: все равно слить данные, т.к. с датасетом хорошо работается, но все важные обновления апдейтить в базу по мере появления вариант 3: все время работать с базой и дергать только ее я бы сделана публичный датасет(дататэйбл) с данными.в конструторе 1ой форме делать
а во 2ой форме спокойно добавлять в базу и одновременно в датасет, или перезаливать конкретную табличку все зависит от объемов ваших данных, активности работы с ними и от вида работы с базой и т.п з.ы. база у вас что ли через студию подключена?не программно?
0
|
||||||
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 21:53 [ТС] | |
|
Да база подключена через студью, опыта работы никакого с БД нет =) Поэтому что значит сделать публичный датасет не понимаю =) надо почитать.
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
||||||
| 16.10.2010, 22:17 | ||||||
|
советую просто освоиться в ado.net)лучше подключение к базе самому написать. во-первых, всегда ясно и видно, что где происходит, и всегда сам понимаешь, как управлять подключением.студия, насколько я понимаю, создает компоненты подключения для разных элементов по отдельности. логика в этом есть, но потом теряешься в их количестве.
публичный датасет - это я имею в виду просто сделать его public)) как пример. тут просто несколькими строчками создается и закрывается соединение
0
|
||||||
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 16.10.2010, 23:51 [ТС] | |
|
А разве я не могу напрямую к таблице обратиться? Мне кажется я где-то видел такое. По названию таблицы к нужной ячейке? Таблица то подключена к приложению, а уже в каждой форме я её к разным вьюшкам цепляю.
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 16.10.2010, 23:59 | |
|
хмм.насколько я понимаю, нет. но могу ошибаться.
смотря,что вы имеет в виду.мне кажется, вы немножко путаете суть бд и суть server-эксплорера, который вам облегчает использование базы. таблица не то чтобы подключена к приложению, а приложение имеет связь с базой. обращение к таблицам происходит,как ни крути, через sql-левые запросы (в частных случаях случаях с sql-поддерживающими базами). когда вы через студию цепляете базу, она создаст датасет с вашими табличками. скорее всего,это вы и приняли за прямое обращение. что-нибудь типа вашdataset.Tables["Таблица"]
1
|
|
|
|
||||||||||||
| 17.10.2010, 00:32 | ||||||||||||
|
piloterist, тебе действительно следует почитать книгу по ADO.NET. Когда ты будешь знать как все это сделать вручную, ты легко соринтируешься, что тебе делает студия автоматом.
![]() когда в студии авотматом делается датасет, то в нем создаются копии таблиц БД и к ним можно обращаться как к свойствам датасета (dataSet.MyTable), т.е. как хочет автор "напрямую". Но, все это (датасет, адаптеры, источники) создается в виде экземпляров классов на каждой форме. Что касательно проблемы , тут все просто. 1) ничего во вторую форму передавать не нужно и обратно ничего получать тоже не нужно. 2) рядом с комбобоксом ставится кнопка на добавление записей и в обработчик пишется в таком стиле:
4)после успешного внесения изменений перед закрытием формы2 следует втыкнуть такую строку this.DialogResult = DialogResult.OK; (я использую это что бы показать что окно успешно выполнило свою функцию) 5)вместо коментария показанного в п.2 ставишь выборку адаптера, который у тебя отвечает за загрузку в comboBox. Как правило он выглядит приблизительно так
Вот и все
2
|
||||||||||||
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 17.10.2010, 00:36 | |
|
0
|
|
|
|
||||
| 17.10.2010, 01:00 | ||||
![]() поэтому в выше показанном коде нельзя написать вашdataset.Таблица.
1
|
||||
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 17.10.2010, 01:08 | |
|
да, согласна, немного не про то)
наверняка как-то можно и программно задать такое именное соответствие. надо озадачиться)
1
|
|
|
4 / 4 / 0
Регистрация: 10.10.2009
Сообщений: 301
|
|
| 17.10.2010, 11:33 [ТС] | |
|
Спасибо большое. Буду пробовать.
Я не много не понял про добавление данных в ComboBox. смысл в том чтобы изначально данные туда попадали без всяких кнопок. А кнопка только при необходимости пополнить выбираемый список. В принцепи меня устроил бы и способ обращения вашdataset.Tables["Таблица"] т.к. название таблицы и датасета я знаю так как сам их и делаю.
0
|
|
|
271 / 203 / 13
Регистрация: 18.06.2010
Сообщений: 491
|
|
| 17.10.2010, 11:34 | |
|
так вы просто вынесите добавление в комбо либо в конструктор формы 1,либо в onload)в отдельную функцию.а когда туда будет приходить новое значение, как предложил nio, опять вызвать эту функцию
0
|
|
| 17.10.2010, 11:34 | |
|
Помогаю со студенческими работами здесь
20
Обращение к элементу на другой форме
Обращение к переменной одной формы, обрабатывая событие на другой форме...
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
Модульный подход на примере 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-код на мобильном и вы увидите, что появится джойстик для управления главным героем.
. . .
|
|
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
|
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
|
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|