Форум программистов, компьютерный форум, киберфорум
C# Windows Forms
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
5 / 5 / 3
Регистрация: 15.01.2017
Сообщений: 690
.NET 4.x

Как выполнить обновление изменений в источнике данных после изменения значения ячейки в dataGridView?

06.03.2019, 08:27. Показов 3754. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пользователь вносит изменения в ячейку.
Событие `CellEndEdit` срабатывает.
В методе `Save()` в строке `adapter.Update(table_2);` отображаются изменения.
В базе данных изменения не отображаются(изменения не сохраняются в базу данных).

Если пользователь вызывает метод `Save()` с помощью кнопки, то изменения отображаются в базе данных(в таблице источнике данных `dataGridView`).

Тоже самое происходит с событием `CellValueChanged`.
Событие CellValueChanged запускается.
В методе `Save ()` изменения отображаются в строке "adapter.Update (table_2);".
Изменения не отображаются в базе данных (изменения не сохраняются в базе данных).

Вопрос.
Как выполнить обновление изменений в источнике данных после изменения значения ячейки в dataGridView?
Миниатюры
Как выполнить обновление изменений в источнике данных после изменения значения ячейки в dataGridView?  
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
06.03.2019, 08:27
Ответы с готовыми решениями:

Обновление значения поля для всех записей, после обновления значения поля в источнике данных (справочнике)?
Комбокс "lst_pic_name" заполняется из справочника. Поле "pic_path_frm" заполняется кодом: Private Sub lst_pic_name_AfterUpdate() ...

Фиксация даты на изменения другой ячейки, защита данных ячейки от изменений следующим днем
Добрый день, прошу помочь с решением данной задачи. Существует 2 строки, например номер 3 и 10. В строке 10 начиная со столбца Н...

Как выполнить обновление формы после изменения динамически созданного содержимого
Как выполнить обновление формы. Например: после удаления или добавления информации нужно без перезапуска программы обновить её (работаю с...

7
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
06.03.2019, 09:43
Soft17, Если источник правильно подключен, то ничего больше не надо придумывать. А если БД то Update запускать нужно.
1
5 / 5 / 3
Регистрация: 15.01.2017
Сообщений: 690
06.03.2019, 09:44  [ТС]
PoPsa85,

Забыл код.
Код.
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
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
private void dataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            i++;
            Save();
            richTextBox1.Text += i + " Event - `CellEndEdit` \r\n";
        }
 
 
     public DataTable CreateCmds()
            {
                table_2 = new DataTable();
                try
                {
                    string connectionString = @"Data Source=.\SQLEXPRESS1;Initial Catalog=Prb;Integrated Security=True";              
 
                    string queryString = "SELECT * FROM tbl_01_Groups";
 
                    using (SqlConnection connection = new SqlConnection(connectionString))
                    {
                        adapter = new SqlDataAdapter();
                        adapter.SelectCommand = new SqlCommand(queryString, connection);
                        SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
 
                        connection.Open();
 
                        adapter.Fill(table_2);
                    }
 
                }
                catch (Exception ex)
                {
 
                    string s = ex.Message;
                    string t = ex.StackTrace;
                    // throw;
                }
 
                return table_2;
            }
 
            public void Save()
            {
                string connectionString = @"Data Source=.\SQLEXPRESS1;Initial Catalog=Prb;Integrated Security=True";
 
                string queryString = "SELECT * FROM tbl_01_Groups";
 
                using (SqlConnection connection = new SqlConnection(connectionString))
                {
                    adapter = new SqlDataAdapter();
                    adapter.SelectCommand = new SqlCommand(queryString, connection);
                    SqlCommandBuilder builder = new SqlCommandBuilder(adapter);
 
                    connection.Open();
 
                    adapter.Update(table_2);
                }
            }

Или

C#
1
2
3
4
5
6
private void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e)
        {
            i++;
            Save();
            richTextBox1.Text += i + " Event - `CellValueChanged` \r\n";
        }
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
06.03.2019, 09:56
Soft17, Сначала в адаптер нужно команду добавить. Можно через билдер.
C#
1
2
adapter.UpdateCommand = builder.GetUpdateCommand(); //Добавили
adapter.Update(table_2); //Обновили
P.S. Лучше на кнопку повесить.
1
5 / 5 / 3
Регистрация: 15.01.2017
Сообщений: 690
06.03.2019, 10:15  [ТС]
Цитата Сообщение от PoPsa85 Посмотреть сообщение
P.S. Лучше на кнопку повесить.
Цитирую вопрос:
Цитата Сообщение от Soft17 Посмотреть сообщение
Если пользователь вызывает метод `Save()` с помощью кнопки, то изменения отображаются в базе данных(в таблице источнике данных `dataGridView`).
вы наверное не заметили или я вас неправильно понял?
Изменил код
Изменённые места отмечены комментарием "// Добавил".


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
35
36
37
38
39
40
41
42
43
44
 private void dataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            dataGridView1.EndEdit(); // Добавил
 
            Save();
 
            i++;
            richTextBox1.Text += i + " Event - `CellEndEdit` \r\n";
        }
 
 
        public DataTable CreateCmds()
        {
            table_2 = new DataTable();
            try
            {
                string connectionString = @"Data Source=.\SQLEXPRESS1;Initial Catalog=Prb;Integrated Security=True";
 
                string queryString = "SELECT * FROM tbl_01_Groups";
 
                using (SqlConnection connection = new SqlConnection(connectionString))
                {
                    adapter = new SqlDataAdapter();
                    adapter.SelectCommand = new SqlCommand(queryString, connection);
 
                    builder = new SqlCommandBuilder(adapter);
                    adapter.UpdateCommand = builder.GetUpdateCommand(); //Добавил
 
                    connection.Open();
 
                    adapter.Fill(table_2);
                }
 
            }
            catch (Exception ex)
            {
 
                string s = ex.Message;
                string t = ex.StackTrace;
                // throw;
            }
 
            return table_2;
        }

Логика по которой работает приложение на текущий момент:
- пользователь. вошёл в ячейку;
- пользователь. внёс изменения;
- пользователь. Нажал "Enter";
- приложение. вышло из ячейки и перенесло фокус;
- приложение. изменения в базе данных не сохранились;

- пользователь. переместил фокус на ячейку в которую вносил изменения;
- пользователь. нажал "F2";
- приложение. вошло в ячейку;
- пользователь. нажал "Esc";
- приложение. изменения в базе сохранились;
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
06.03.2019, 10:27
Soft17, Всё-таки вам лучше обратиться в соответствующий раздел. Попробуйте так:
C#
1
2
3
4
5
6
7
8
9
DataTable changes = ((DataTable)dataGridView1.DataSource).GetChanges();
if (changes != null)
{            
    builder = new SqlCommandBuilder(adapter);
    adapter.UpdateCommand = builder.GetUpdateCommand();
    adapter.Update(changes);
    
    ((DataTable)dataGridView1.DataSource).AcceptChanges();
}
1
5 / 5 / 3
Регистрация: 15.01.2017
Сообщений: 690
06.03.2019, 10:52  [ТС]
Цитата Сообщение от PoPsa85 Посмотреть сообщение
Всё-таки вам лучше обратиться в соответствующий раздел.
Вы имеете ввиду раздел форума?
ADO?
0
 Аватар для PoPsa85
814 / 561 / 240
Регистрация: 01.07.2018
Сообщений: 1,818
06.03.2019, 11:09
Soft17, Именно.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
06.03.2019, 11:09
Помогаю со студенческими работами здесь

Изменение содержимого одной ячейки Datagridview после изменения другой ячейки
Здравствуйте. Есть Datagridview с 2 столбцами. Столбцы типа ComboBox. В 1 столбце уже забиты значения, 2 столбец пустой. Необходимо сделать...

Обновление содержимого DataGridView после изменений в базе
Все примеры найденные в интернете не помогают. Посмотрите пожалуйста кто может проект,архив прилагаю. Например в Rashodi.cs со...

Обновление содержимого DataGridView после изменений в базе
Проблема в следующем. Добавляю новую строку в таблицу: clientsTableAdapter.InsertQuery(id, name, email);Привязанный к таблице...

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

Кто является причиной изменения значения ячейки DataGridView?
Добрый день! Есть обработчик событий CellValueChanged, прикрученный к DataGridView. Код, написанный в CellValueChanged, должен...


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
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. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru