С Новым годом! Форум программистов, компьютерный форум, киберфорум
C#: Базы данных, Entity Framework
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
1 / 1 / 0
Регистрация: 14.01.2021
Сообщений: 33
1

Получаю ошибку при попытке сохранить изменения dataGridView

17.03.2022, 00:03. Показов 651. Ответов 0

Author24 — интернет-сервис помощи студентам
Я сохраняю изменения в базе данных, по нажатию на кнопку кнопку после изменения данных в dataGridView, но получаю сообщение об ошибке "Нарушение параллелизма: команда UpdateCommand затронула 0 из ожидаемых 1 записей"
Вот сам код:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
{
label3.Text = "rbt";
string script = "SELECT id, name, Model_preparation_R_Hr, Time_for_preparation_hr, Time_for_post_processing_hr, YZV_work FROM rbt;";
mycon = new MySqlConnection(connect);
mycon.Open();
MySqlDataAdapter ms_data = new MySqlDataAdapter(script, connect);
var cb = new MySqlCommandBuilder(ms_data);
cb.GetInsertCommand();
DataSet ds = new DataSet();
ms_data.Update(dataGridView1.DataSource as DataTable);
ms_data.InsertCommand = cb.GetInsertCommand();
ms_data.InsertCommand.CommandText += "; select * from rbt where id = last_insert_id();";
ms_data.InsertCommand.UpdatedRowSource = UpdateRowSource.FirstReturnedRecord;        
}
У меня есть несколько блоков такого кода для каждого элемента ComboBox. Все они одинаковые, но на этом выдает ошибку, почему так может быть?

Пример рабочего блока в котором я могу вставлять и обновлять любую строку в таблице, которую я вызываю в этом блоке:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
else if (comboBox1.SelectedItem == "Rash")
{
label3.Text = "rash";
string script = "SELECT id, name, Spirt_10_Litr, gloves, knife, detergent_PH11_Litr FROM rash;";
mycon = new MySqlConnection(connect);
mycon.Open();
MySqlDataAdapter ms_data = new MySqlDataAdapter(script, connect);
var cb = new MySqlCommandBuilder(ms_data);
cb.GetInsertCommand();
ms_data.Update(dataGridView1.DataSource as DataTable);
ms_data.InsertCommand = cb.GetInsertCommand();
ms_data.InsertCommand.CommandText += "; select * from rash where id = last_insert_id();";
ms_data.InsertCommand.UpdatedRowSource = UpdateRowSource.FirstReturnedRecord;
}
Я также знаю, что ошибка возникает в строке:
C#
1
ms_data.Update(dataGridView1.DataSource as DataTable);
Я могу вставлять и обновлять любую строку в таблице, которую я вызываю во втором блоке, но в таблице первого блока я могу вставлять новые строки и обновлять только некоторые из них(а точнее только 3-ю и 4-ю строки из четырех), а не все.

Я также думаю, что в моем коде может быть конфликт между блоками вывода таблиц через ComboBox и блоком сохранения через button_click:

Вот так я вывожу таблицу и заполняю свой dataGridView:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
else if (comboBox1.SelectedItem == "rbt")
{
label3.Text = "rbt";
string script = "SELECT * FROM hardlight.rbt;";
mycon = new MySqlConnection(connect);
mycon.Open();
MySqlDataAdapter ms_data = new MySqlDataAdapter(script, connect);
SD.DataTable table = new SD.DataTable();
ms_data.Fill(table);
DataSet ds = new DataSet();
dataGridView1.DataSource = table;
mycon.Close();
ds.AcceptChanges();
}
Что я делаю неправильно? Почему я могу работать с некоторыми таблицами в моей БД без проблем, но эта конкретная таблица не работает должным образом?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
17.03.2022, 00:03
Ответы с готовыми решениями:

При попытке зайти под админом получаю ошибку
Всем привет, В Kubuntu 17.10 имея : lsb_release -d; uname -r; uname -i Description: Ubuntu...

При попытке сохранить изменения в файле вылетает BSOD
Здравствуйте. В сетевой папке находиться exel файл. После внесения в него изменений и попытке...

При попытке сохранить изменения в Widgetkit выбивает Forbidden
При попытке сохранить изменения в Widgetkit выбивает Forbidden. Подскажите, пожалуйста, как...

AsRock 890fx deluxe4, биос постоянно виснет при попытке сохранить изменения и при загрузке.
Здравствуйте. Вчера купил мп AsRock 890fx deluxe4, биос постоянно виснет при попытке сохранить...

Ошибка при попытке сохранить введенные данные из datagridview в mysql
Выбивает ошибку System.NullReferenceException: "Ссылка на объект не указывает на экземпляр...

0
17.03.2022, 00:03
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
17.03.2022, 00:03
Помогаю со студенческими работами здесь

При попытке обращения к данным из базы с полем с типом Set получаю ошибку TypeError: 'set' object is not subscriptable
C базой соединяюсь и данные которые мне необходимо получить я получаю в итоге я получаю такой...

При попытке сохранить данные Access выдает ошибку аргумента
При попытке сохранить данные выдает ошибку аргумена. Если я сожму базу то 3-4 записи проходят а...

Как сохранить изменения при изменении шрифта в DataGridView?
Доброго времени суток! Изменяю шрифт dataGridView через FontDialog. Изменения шрифта остаются...

При попытке изменения типа раздела гибернации выдает ошибку ввода/вывода
Acronis Disk Director не помогает. В чем проблема?

Как сохранить изменения сделанные в DataGridView в БД при использовании linq2db?
Заполнить dataGridView у меня получилось: using (DBSystem dbSystem = new DBSystem()) { ...

При попытке сохранить таблицы выдает ошибку "Введите число!"
Пытаюсь сохранить таблицы, выдает ошибку "Введите число!" Какое число я забыла?


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
Как написать микросервис на Go/Golang
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C#
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
Как создать игру "Танчики" на Unity3d и C#
InfoMaster 14.01.2025
Разработка игр – это увлекательный процесс, сочетающий в себе творчество и технические навыки. В этой статье мы рассмотрим создание классической игры "Танчики" с использованием Unity3D и языка. . .
Организую платный онлайн микро-курс по доработке Android-клиента Telegram
_Ivana 14.01.2025
Официальная версия и распространенные форки не полностью устраивают? Сделай свою кастомную версию клиента! 4 занятия по 2 часа (2 недели пн, ср 19:00-21:00 по Москве). Первое вводное занятие. . .
Как создать приложение для фитнеса для iOS/iPhone на Kotlin
InfoMaster 14.01.2025
Создание собственного фитнес-приложения — это не только захватывающий, но и полезный процесс, ведь оно может стать вашим верным помощником на пути к здоровому и активному образу жизни. В современных. . .
Как создать приложение магазина для iOS/iPhone на Swift
InfoMaster 14.01.2025
Введение в разработку iOS-приложений Разработка приложений для iPhone и других устройств на базе iOS открывает огромные возможности для создания инновационных мобильных решений. В данной статье мы. . .
Это работает. Скорость асинхронной логики велика. Вопрос видимо останется в стабильности. Плата - огонь!
Hrethgir 13.01.2025
По прошлому проекту в Logisim Evolution https:/ / www. cyberforum. ru/ blogs/ 223907/ blog8781. html прилагаю файл архива проекта в Gowin Eda. Восьмибитный счётчик из сумматора+ генератор сигнала. . .
UserScript для подсветки кнопок языков программировани­­­­я в зависимости от текущего раздела
volvo 13.01.2025
В результате работы этого скрипта подсвечиваются нужные кнопки не только в форме быстрого ответа, но и при редактировании сообщения: / / ==UserScript== / / @name CF_DefaultLangSelect / / . . .
Введение в модели и алгоритмы машинного обучения
InfoMaster 12.01.2025
Машинное обучение представляет собой одну из наиболее динамично развивающихся областей искусственного интеллекта, которая фокусируется на разработке алгоритмов и методов, позволяющих компьютерам. . .
Как на Python создать нейросеть для решения задач
InfoMaster 12.01.2025
В контексте стремительного развития современных технологий особое внимание уделяется таким инструментам, как нейросети. Эти структуры, вдохновленные биологическими нейронными сетями, используются для. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru