Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.63/8: Рейтинг темы: голосов - 8, средняя оценка - 4.63
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
MS Access

Сохранение изменений в базу данных

01.12.2015, 15:55. Показов 1804. Ответов 10
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день помогите пожалуйста разобраться как сохранить изменения, которые ты сделал в datagridview, в базу дн. У меня в datagridview выводится информация с двух разных таблиц, запрос для вывода информации таков:

C#
1
dbAdapter1 = new OleDbDataAdapter(@"SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1 ", dbCon);
Когда я пишу для сохранения следующее:

C#
1
 dbAdapter1.Update(dataTable);
Мне выбивает такую ошибку:

Для обновления требуется действительный 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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using System.Windows.Forms;
using System.Data.OleDb;
 
namespace WindowsFormsApplication6
{
    public partial class Form1 : Form
    {
 
        public Form1()
        {
            InitializeComponent();
        }
 
       public void Form1_Load(object sender, EventArgs e)
        {
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Клас". При необходимости она может быть перемещена или удалена.
            this.класTableAdapter.Fill(this.databaseDataSet.Клас);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Предмети". При необходимости она может быть перемещена или удалена.
            this.предметиTableAdapter.Fill(this.databaseDataSet.Предмети);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Вчителі". При необходимости она может быть перемещена или удалена.
            this.вчителіTableAdapter.Fill(this.databaseDataSet.Вчителі);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Предмети". При необходимости она может быть перемещена или удалена.
            this.предметиTableAdapter.Fill(this.databaseDataSet.Предмети);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Вчителі". При необходимости она может быть перемещена или удалена.
            this.вчителіTableAdapter.Fill(this.databaseDataSet.Вчителі);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Клас". При необходимости она может быть перемещена или удалена.
            this.класTableAdapter.Fill(this.databaseDataSet.Клас);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Предмети". При необходимости она может быть перемещена или удалена.
            this.предметиTableAdapter.Fill(this.databaseDataSet.Предмети);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Вчителі". При необходимости она может быть перемещена или удалена.
            this.вчителіTableAdapter.Fill(this.databaseDataSet.Вчителі);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Клас". При необходимости она может быть перемещена или удалена.
            this.класTableAdapter.Fill(this.databaseDataSet.Клас);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Предмети". При необходимости она может быть перемещена или удалена.
            this.предметиTableAdapter.Fill(this.databaseDataSet.Предмети);
            // TODO: данная строка кода позволяет загрузить данные в таблицу "databaseDataSet.Вчителі". При необходимости она может быть перемещена или удалена.
            this.вчителіTableAdapter.Fill(this.databaseDataSet.Вчителі);
            //this.укрмова1TableAdapter1.Fill(this.databaseDataSet.Укрмова1);
 
        }
     public   OleDbConnection dbCon = new OleDbConnection(@"Provider=Microsoft.Jet.OLEDB.4.0;Data Source=Database.mdb");
     public   OleDbDataAdapter dbAdapter1;
     public   DataTable dataTable;
 
 
 
        public void button2_Click(object sender, EventArgs e)
        {
 
            dbAdapter1 = new OleDbDataAdapter(@"SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1 ", dbCon);
            dataTable = new DataTable();
            dbAdapter1.Fill(dataTable);
            dataGridView2.DataSource = dataTable;
 
        }
 
        public void button1_Click(object sender, EventArgs e)
        {
    
 
            dbAdapter1.Update(dataTable);
 
        }
 
 
 
 
 
 
    }
}
Вложения
Тип файла: zip Архив ZIP - WinRAR.zip (824.6 Кб, 5 просмотров)
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
01.12.2015, 15:55
Ответы с готовыми решениями:

Сохранение изменений в базу данных
Здравствуйте, уважаемые программисты! Я начал первые шаги в освоении баз данных и решил, что самым простым инструментарием должны быть С#...

Сохранение изменений DataGridView в базу данных
Нужна помощь с сохранением изменений из DataGridView в БД MS SQL, пересмотрел много различных тем, попробовал сделать BindingSource...

Не происходит сохранение изменений в базу данных
Добрый вечер. Я не могу сохранить изменения, которые я сделал в datagridview, в базу данных при выполнении такого кода для сохранения: ...

10
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
02.12.2015, 22:29  [ТС]
Я очень прошу помогите я уже не знаю сколько дней на это потратил, ничего не получается

Добавлено через 21 час 42 минуты
Еще раз добрый вечер. Я понимаю что я всем надоел, но мне действительно нужна помощь, я нашел такой пример:

C#
1
укрмова1TableAdapter1.Fill(databaseDataSet.Укрмова1);
пробую его, сохранения не происходит, я не понимаю почему? Может потому что я информацию вывожу из разных таблиц? В чем может быть проблема?
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.12.2015, 12:04
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
я нашел такой пример:
укрмова1TableAdapter1.Fill(databaseDataS et.Укрмова1);
пробую его, сохранения не происходит, я не понимаю почему?
Потому что метод Fill заполняет таблицу данными, а чтобы сохранить их нужен метод Update().
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
Для обновления требуется действительный UpdateCommand при передаче коллекции DataRow с измененными строками.
Если вы создаете новый DataAdapter и хотите, чтобы он сохранял изменения, то должны сформировать соответствующие команды Insert,Update,Delete. Обычно это делается с помощью CommandBuilder, но в вашем случае это не получится, т.к. в запросе у вас 2 таблицы (сам запрос тоже очень странный, т.к. результатом его будет произведение двух таблиц). Так что вам нужно эти команды сформировать самостоятельно.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
03.12.2015, 16:58  [ТС]
Я так и думал, но я не могу написать код тех команд, я пробовал для Update написать такое:

C#
1
2
3
4
5
6
7
8
 dbAdapter1 = new OleDbDataAdapter("SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1 " , dbCon);
 
            dbAdapter1.UpdateCommand = new OleDbCommand("UPDATE Укрмова1 SET [Оцінка за 1 см] = ?, [Оцінка за 2 см] = ?, Річна = ? ");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 1 см]", OleDbType.VarChar, 50, "[Оцінка за 1 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 2 см]", OleDbType.VarChar, 50, "[Оцінка за 2 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("Річна", OleDbType.VarChar, 50, "Річна");
            dbAdapter1.UpdateCommand.Connection = dbCon;
            dbAdapter1.Update(databaseDataSet.Tables[0]);
нашел пример в интернете но не помогает, помогите пожалуйста написать этот код.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
03.12.2015, 18:28
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
UPDATE Укрмова1 SET [Оцінка за 1 см] = ?, [Оцінка за 2 см] = ?, Річна = ?
Если код сработает, то у всех учащихся будут одинаковые оценки. Должно быть еще условие " WHERE Код=?".
Подразумевается, что Код-это код ученика. Вот только в вашей БД 11 таблиц с таким кодом,что неправильно. Делайте одну и добавляйте туда номер класса.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
03.12.2015, 22:57  [ТС]
Я изменил код на такое:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
      public void button1_Click(object sender, EventArgs e)
        {
 
            dbAdapter1.UpdateCommand = new OleDbCommand("UPDATE Укрмова1 SET [Оцінка за 1 см] = ?, [Оцінка за 2 см] = ?, Річна = ? WHERE Код=? ");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 1 см]", OleDbType.VarChar, 50, "[Оцінка за 1 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 2 см]", OleDbType.VarChar, 50, "[Оцінка за 2 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("Річна", OleDbType.VarChar, 50, "Річна");
            dbAdapter1.UpdateCommand.Connection = dbCon;
            dbAdapter1.Update(databaseDataSet.Укрмова1);
 
            укрмова1TableAdapter1.Update(databaseDataSet.Укрмова1);
            
 
        }
но все равно не помогает, я не знаю что делать провозился с этим куча времени, помогите пожалуйста.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
04.12.2015, 10:20
Нет добавления параметра для Кода.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
05.12.2015, 14:40  [ТС]
я добавил параметр для кода все равно ничего не помогает (

C#
1
2
3
4
5
6
7
8
9
10
dbAdapter1.UpdateCommand = new OleDbCommand("UPDATE Укрмова1 SET [Оцінка за 1 см] = ?, [Оцінка за 2 см] = ?, Річна = ? WHERE Код=? ");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 1 см]", OleDbType.VarChar, 50, "[Оцінка за 1 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("[Оцінка за 2 см]", OleDbType.VarChar, 50, "[Оцінка за 2 см]");
            dbAdapter1.UpdateCommand.Parameters.Add("Річна", OleDbType.VarChar, 50, "Річна");
            dbAdapter1.UpdateCommand.Parameters.Add("Код", OleDbType.Integer, 10, "Код");
            dbAdapter1.UpdateCommand.Connection = dbCon;
            dbAdapter1.Update(databaseDataSet.Укрмова1);
 
 
            укрмова1TableAdapter1.Update(databaseDataSet.Укрмова1);
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
05.12.2015, 16:31
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1
Запрос таким и остался? Надо добавить еще Укрмова1.Код.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
05.12.2015, 16:43  [ТС]
сделал так, все равно ничего, посмотрите целый проект может я что-то напутав, спасибо что помогаете.

C#
1
@"SELECT Прізвище, Імя, Код, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1 ", dbCon);
Вложения
Тип файла: rar Архив WinRAR.rar (279.7 Кб, 5 просмотров)
0
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
07.12.2015, 21:35  [ТС]
Пожалуйста помогите, просто очень надо с этим разобраться, или подскажите как вывести информацию из двух таблиц и чтобы было проще сохранить изменения.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.12.2015, 21:35
Помогаю со студенческими работами здесь

Вывод, сохранение изменений, добавление новых записей в базу MS SQLCE 4.0
Доброе время суток, задам изъезженный вопрос наверное в 100 раз, но решение найти так и не смог, ровно как и примеры. Программировать...

Внесение изменений в базу данных
Подскажите, пожалуйста, почему не сохраняются данные в базу данных :(

Сохранение изменений в Базе Данных
Всем доброго времени суток! Есть проблема, не могу сохранить изменения в базе данных. На форме есть datagridview, по нажатию кнопки выходит...

Сохранение изменений из datagridview в базе данных
Привязываю datagridview к таблице в бд вызывая метод Load(); (использую sqlite). Но никак не могу найти и понять по найденной информации-...

Сохранение изменений в БД при редактировании данных
Создал таблицу с помощью GridControl из комплекта Devexpress https://www.cyberforum.ru/vb-net/thread420939.html Данные отображаются, но...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Новые блоги и статьи
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru