Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.93/15: Рейтинг темы: голосов - 15, средняя оценка - 4.93
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
.NET 4.x

DataGridView Ошибка при сохранении внесенных изменений

28.11.2017, 06:34. Показов 3090. Ответов 18
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Пытаюсь сделать сохранение внесенных изменений и получаю вот такую ошибку (System.InvalidOperationException: "Для обновления требуется действительный UpdateCommand при передаче коллекции DataRow с измененными строками.)

Кликните здесь для просмотра всего текста


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
58
59
60
61
62
63
64
namespace gorod.net
{
    public partial class Social_sphere : Form
    {
 
        public Social_sphere()
        {
            InitializeComponent();
        }
        private void Social_sphere_Load_1(object sender, EventArgs e)
        {
            // TODO: данная строка кода позволяет загрузить данные в таблицу "gorodDataSet.DETAIL". При необходимости она может быть перемещена или удалена.
            this.dETAILTableAdapter.Connection = GlobalParameters.Connection;
            this.dETAILTableAdapter.Fill(this.gorodDataSet.DETAIL);
        }
        private void comboBox1_SelectedIndexChanged(object sender, EventArgs e)
        {
            if (comboBox1.SelectedIndex == 0)
            {
                GlobalParameters.sda = new SqlDataAdapter("SELECT DEPARTMENT, SUBSECTION, TARGET_ARTICLE, ASPECT, ADD_BK, ACCEPTED, ADJUSTMENT, ACTIVE, ATTRIBUTE, DATEIN From Detail where department = 608 and ATTRIBUTE = 0.1 ORDER BY department", GlobalParameters.Connection);
                GlobalParameters.dt = new DataTable();
                GlobalParameters.sda.Fill(GlobalParameters.dt);
                dataGridView1.DataSource = GlobalParameters.dt;
            }
            if (comboBox1.SelectedIndex == 1)
            {
                GlobalParameters.sda = new SqlDataAdapter("SELECT DEPARTMENT, SUBSECTION, TARGET_ARTICLE, ASPECT, ADD_BK, ACCEPTED, ADJUSTMENT, ACTIVE, ATTRIBUTE, DATEIN From Detail where department = 608 and ATTRIBUTE = 0.2 ORDER BY department", GlobalParameters.Connection);
                GlobalParameters.dt = new DataTable();
                GlobalParameters.sda.Fill(GlobalParameters.dt);
                dataGridView1.DataSource = GlobalParameters.dt;
            }
        }    
 
 
        private void dataGridView1_CellEndEdit(object sender, DataGridViewCellEventArgs e)
        {
            dataGridView1.DataError += new DataGridViewDataErrorEventHandler(dataGridView1_DataError);
 
            for (int i = 0; i < dataGridView1.Rows.Count; i++)               //Сложение 5+6=7
            {
                try
                {
                    dataGridView1.Rows[i].Cells[7].Value =
                        Convert.ToDouble(dataGridView1[5, i].Value)
                        + Convert.ToDouble(dataGridView1[6, i].Value);
                }
                catch
                {                 
                    dataGridView1.Rows[i].Cells[6].Value = 0;
                }
            }
        }
 
        private void button2_Click(object sender, EventArgs e)
        {
            dETAILTableAdapter.Update(gorodDataSet);
 
            MessageBox.Show("Изменения сохранены", "Работа с БД", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
        }
 
        private void dataGridView1_DataError(object sender, DataGridViewDataErrorEventArgs e)
        {
            MessageBox.Show("Введите корректную сумму.");
        }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.11.2017, 06:34
Ответы с готовыми решениями:

Ошибка при сохранении изменений в DataGridView
Доброго времени суток! Ребята выручайте! При нажатии на кнопку должны сохраняться изменения, но вылетает такая вот ошибка ...

Ошибка при сохранении изменений в DataGridView
На главной форме проекта, которая загружается первой, имеется подключение к базе данных Access, созданное программно: public static...

Ошибка при сохранении изменений
Приветствую всех. Знаю что задача тривиальна, но тем не менее не могу разобраться. Создаю интерфейс для работы с базой данных (БД в формате...

18
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
28.11.2017, 06:47  [ТС]
Такая же ошибка и с этим вариантом.

Кликните здесь для просмотра всего текста

C#
1
2
3
4
5
        private void button2_Click(object sender, EventArgs e)
        {
            this.dETAILTableAdapter.Update(this.gorodDataSet.DETAIL);
            MessageBox.Show("Изменения сохранены", "Работа с БД", MessageBoxButtons.OK, MessageBoxIcon.Asterisk);
        }
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
28.11.2017, 07:47
У вас не определен UpdateCommand он пустой.
0
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
28.11.2017, 08:41  [ТС]
Я это понял из ошибки, но не знаю, как его реализовать
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
28.11.2017, 08:55
Посмотрите как это делает дизайнер DataSet.
0
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
28.11.2017, 09:25  [ТС]
Я совсем новичок , я Вас не понимаю, буду снова гуглить.
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
28.11.2017, 09:33
Вы пытаетесь рутину писать вручную. В MS Visual Studio это все создается автоматически. Достаточно добавить в проект Набор данных DataSet.xsd, перенести в форму дизайнера источник данных (таблицу базы данных из вкладки источники данных) как все методы станут определены. Вы можете их корректировать. Но работать сразу все будет и в коде дизайнера будет прописан код, можете оттуда взять его, если у вас задача все писать вручную.
1
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
29.11.2017, 05:57  [ТС]
Я попробовал, но там нет кода на обновление и совсем не очевидно как с этим всем работать.

Кликните здесь для просмотра всего текста
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
29.11.2017, 07:36
Зайдите на вкладку Источники данных найдите свой DETAIL перетащите на Form, посмотрите какой код сформировался в Form.cs, Form.Designer.cs, DataSet.Designer.cs и все поймете.
1
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
30.11.2017, 08:09  [ТС]
Не могу понять, что я делаю не так, сделал все с нового проекта добавил, как вы сказали, но поле UpdateCommand мне пришлось выбрать новый так как он был пустой, но теперь он хочет, что бы я ввел команду для обновления, а Вы говорили, что должно быть автоматически.

Кликните здесь для просмотра всего текста
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
30.11.2017, 08:17
Лучший ответ Сообщение было отмечено ToPRaLLI как решение

Решение

UpdateCommand не создается, если вы видоизменили Select по умолчанию. Откройте селект по правой кнопке мыши на Fill, GetData() нажмите изменить. пропишите запрос типа Select * From Detail, нажмите далее, UpdateCommand и все остальные будут заполнены автоматически. Мастер, при нажатии далее покажет какие команды он создал.
1
79 / 102 / 44
Регистрация: 12.05.2015
Сообщений: 476
30.11.2017, 08:33
Лучший ответ Сообщение было отмечено ToPRaLLI как решение

Решение

А еще команды автоматически не будут созданы если у вас нет первичного ключа в таблице
2
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
30.11.2017, 08:39  [ТС]
Что-то не хочет он добавлять автоматом пишет , что все норм, а по факту нет.

Кликните здесь для просмотра всего текста
0
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
30.11.2017, 08:41
Лучший ответ Сообщение было отмечено ToPRaLLI как решение

Решение

Цитата Сообщение от Tessio Посмотреть сообщение
А еще команды автоматически не будут созданы если у вас нет первичного ключа в таблице
Да, кстати, нужно создать уникальный первичный ключ (колонку такую), обычно его называют ID. Установите тип int и задайте автоинкремент.
Это делается в базе данных.
2
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
30.11.2017, 10:11  [ТС]
Создал как Вы сказали и все равно UpdateCommand не создается.
Кликните здесь для просмотра всего текста
0
79 / 102 / 44
Регистрация: 12.05.2015
Сообщений: 476
30.11.2017, 10:55
ToPRaLLI, столбец ID должен быть помечен как PK (первичный ключ true)
1
 Аватар для Козадоев
164 / 154 / 33
Регистрация: 05.03.2013
Сообщений: 876
30.11.2017, 10:56
Это должен быть первичный ключ. У вас свойство в false.
2
0 / 0 / 0
Регистрация: 15.11.2017
Сообщений: 12
01.12.2017, 02:48  [ТС]
Да, действительно помогло!
0
1 / 1 / 0
Регистрация: 28.01.2016
Сообщений: 3
27.12.2017, 07:45
у меня причина была в том, что не было ключевого поля
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.12.2017, 07:45
Помогаю со студенческими работами здесь

Ошибка при сохранении изменений в БД: "Для обновления требуется действительный UpdateCommand"
делаю кнопку сохранения, вылетает ошибка &quot;Для обновления требуется действительный UpdateCommand при передаче коллекции DataRow с...

Обновить данные на форме при сохранении изменений в БД
Здравствуйте! У меня на форме 2 одинаковых панели. панель1 в Label'ы, при открытии формы, выводяться данные sql запроса панель2 в...

Выводит ошибку при сохранении изменений. MS Access
Добавил oleDbDataAdapter из toolbox'а на форму.Соединил с базой MS Access. От нее создал датасет. Добавил datagridview. При создании новой...

Ошибка при сохранении dataGridView в Excel файл.
Хочу сохранить датугридвью в эксель файл. Выдает следующую ошибку. Может я забыл подгрузить какую-нибудь библиотеку? ...

Ошибка 0x0000007e при запуске Windows 7 после изменений, внесенных в msconfig
Привет, при запуске вылетает данная ошибка. Сегодня утром я снял крышку ноута (hp4730s) и снял планку озу(нужно было почитать, что написано...


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

Или воспользуйтесь поиском по форуму:
19
Ответ Создать тему
Новые блоги и статьи
Символьное дифференцирование
igorrr37 13.02.2026
/ * Логарифм записывается как: (x-2)log(x^2+2) - означает логарифм (x^2+2) по основанию (x-2). Унарный минус обозначается как ! */ #include <iostream> #include <stack> #include <cctype>. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL3_image
8Observer8 10.02.2026
Содержание блога Библиотека SDL3_image содержит инструменты для расширенной работы с изображениями. Пошагово создадим проект для загрузки изображения формата PNG с альфа-каналом (с прозрачным. . .
Установка Qt-версии Lazarus IDE в Debian Trixie Xfce
volvo 10.02.2026
В общем, достали меня глюки IDE Лазаруса, собранной с использованием набора виджетов Gtk2 (конкретно: если набирать текст в редакторе и вызвать подсказку через Ctrl+Space, то после закрытия окошка. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru