С Новым годом! Форум программистов, компьютерный форум, киберфорум
Visual Basic .NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
 
Рейтинг 4.70/40: Рейтинг темы: голосов - 40, средняя оценка - 4.70
25 / 26 / 4
Регистрация: 12.12.2011
Сообщений: 197

Как обновить данные в DataGridView при изменении записей в БД

04.04.2012, 08:54. Показов 8167. Ответов 23
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть форма F1 с пустым датагридом. Я делаю двойной щелчок по ячейке и появляется форма F2 с набором записей. Я делаю двойной щелчок по нужной записи и нужная запись через запрос INSERT вносится в таблицу БД, датагрид которой находится на форме F1. Получается ситуация, когда запись в таблицу БД внесена, а датагрид формы F1 пока изменения в таблице БД не показывает. Я так понимаю, что надо делать новый запрос и снова вывести данные датагрида на форму F1. Правильно?

Добавлено через 18 минут
Пока склоняюсь к такому решению: в событии Activated формы F1 создать код, который бы очищал датагрид формы F1, (дальше я уже не уверен) делал новый запрос к БД, получал данные и наполнял датагрид. Привильно?

Добавлено через 4 минуты
Всё получилось

Добавлено через 13 часов 36 минут
Подскажите, какое событие лучше использовать для обновления данных? Сейчас я использую событие Activated. Попробовал в дэбуге, оказалось, что при открытии формы F1 сначала срабатывает событие Activated, потом Load (при загрузке опять делается запрос к БД, как и при Activated), потом снова Activated несколько раз, видимо после загрузки каждого элемента управления формы F1. Выходит, что много делается запросов к БД, что нагружает систему. Решил отказаться от и использования события Activated и выбрал событие GotFocus не формы F1, а датагрида формы F1. Насколько это рационально?
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.04.2012, 08:54
Ответы с готовыми решениями:

Как правильно обновить DataGridView при возврате из другой формы
Опять что-то конструктор поломался:- Private Sub TabPage3_Load(ByVal sender As Object, ByVal e As EventArgs) Handles MyBase.Load ...

Обновить данные в DataGridView не перезапуская приложение
В DataGrid отображена информация из Access таблицы. все работает, все хорошо. После добавления записи в таблицу, поле код, которое является...

Обновить данные в DataGridView из другой формы
На Form1 есть DataGridView. Заполняю его вот так Private Sub FillGridRecipe() GridViewRecipe.Select() db = New...

23
 Аватар для gitarillo
755 / 554 / 48
Регистрация: 17.06.2010
Сообщений: 1,041
Записей в блоге: 1
06.04.2012, 17:20
Студворк — интернет-сервис помощи студентам
Цитата Сообщение от paa66 Посмотреть сообщение
Кстати, у меня не функция, а процедура
Так а как ты присвоишь источник датагриду, если правый операнд не возвращает значения. вот он (грид) и пустой у тебя. Сделай функцию, возвращающую DataTable с данными и присваивай.
1
25 / 26 / 4
Регистрация: 12.12.2011
Сообщений: 197
07.04.2012, 18:15  [ТС]
Нифига с функцией не заработало
0
5 / 5 / 0
Регистрация: 23.11.2010
Сообщений: 28
09.04.2012, 01:42
VB.NET
1
2
3
4
TableAdapter.Update("Поле 1", "Поле 2", "Поле 3")
Me.Hide()
F1.Show()
F1.TableAdapter.Fill(F1.DataSet.Твоя_Таблица)
0
25 / 26 / 4
Регистрация: 12.12.2011
Сообщений: 197
09.04.2012, 09:31  [ТС]
Это у меня есть, правда, немного не так:
VB.NET
1
2
DA = New OleDb.OleDbDataAdapter(SqlCom) 'DA - это датаадаптер
        DA.Fill(dt) ' dt - это дататэйбл
Этот код у меня находится в функции, делающей запросы к БД типа SELECT. А другая функция её вызывает, вот часть кода другой функции:
VB.NET
1
2
F1.DataGridView1.DataSource = Nothing 'сначала удаляю старые данные датагрида
       F1.DataGridView1.DataSource = GetDt(SqlQuery) ' здесь вызываю функцию SELECT получения изменённых данных таблицы
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
09.04.2012, 09:31
Помогаю со студенческими работами здесь

Не получается обновить данные в БД SQL Server при изменении данных в dataGridView
ADO.NET C# Добавлено через 2 минуты using System; using System.Collections.Generic; using System.ComponentModel; using...

Как обновить данные в одной подчиненной форме при изменении данных в другой
Вроде ничего сложного, но не получается... Ситуация такая: есть таблица с обработанным написаниями клиентов Таб1 и таблица с...

Как правильно обновить данные для списка при изменении данных в другом фрагменте?
Здравствуйте. Подскажите как правильно обновить данные для адаптера списка в главном фрагменте при изменении списка в дочернем фрагменте....

При изменении записей datagrid записать данные в БД
Привет всем форумчанам. В общем пока летние каникулы я решил немного заняться собой в плане образования. Что мы имеем: есть WPF...

Как обновить данные в dataGridView из БД Sql
Доброго времени суток. Подскажите пожалуйста, не могу разобраться! Есть dataGridView, есть таблица SQL, если в БД Таблицу вносят новую...


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

Или воспользуйтесь поиском по форуму:
24
Ответ Создать тему
Новые блоги и статьи
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru