2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
1
MS Access

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

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

Author24 — интернет-сервис помощи студентам
Добрый день помогите пожалуйста разобраться как сохранить изменения, которые ты сделал в 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
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
01.12.2015, 15:55
Ответы с готовыми решениями:

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

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

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

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

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

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

C#
1
укрмова1TableAdapter1.Fill(databaseDataSet.Укрмова1);
пробую его, сохранения не происходит, я не понимаю почему? Может потому что я информацию вывожу из разных таблиц? В чем может быть проблема?
0
784 / 615 / 273
Регистрация: 04.08.2015
Сообщений: 1,707
03.12.2015, 12:04 3
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
я нашел такой пример:
укрмова1TableAdapter1.Fill(databaseDataSet.Укрмова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  [ТС] 4
Я так и думал, но я не могу написать код тех команд, я пробовал для 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
784 / 615 / 273
Регистрация: 04.08.2015
Сообщений: 1,707
03.12.2015, 18:28 5
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
UPDATE Укрмова1 SET [Оцінка за 1 см] = ?, [Оцінка за 2 см] = ?, Річна = ?
Если код сработает, то у всех учащихся будут одинаковые оценки. Должно быть еще условие " WHERE Код=?".
Подразумевается, что Код-это код ученика. Вот только в вашей БД 11 таблиц с таким кодом,что неправильно. Делайте одну и добавляйте туда номер класса.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
03.12.2015, 22:57  [ТС] 6
Я изменил код на такое:

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
784 / 615 / 273
Регистрация: 04.08.2015
Сообщений: 1,707
04.12.2015, 10:20 7
Нет добавления параметра для Кода.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
05.12.2015, 14:40  [ТС] 8
я добавил параметр для кода все равно ничего не помогает (

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
784 / 615 / 273
Регистрация: 04.08.2015
Сообщений: 1,707
05.12.2015, 16:31 9
Цитата Сообщение от Taras_lebdyk Посмотреть сообщение
SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM Учні1клас, Укрмова1
Запрос таким и остался? Надо добавить еще Укрмова1.Код.
1
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
05.12.2015, 16:43  [ТС] 10
сделал так, все равно ничего, посмотрите целый проект может я что-то напутав, спасибо что помогаете.

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  [ТС] 11
Пожалуйста помогите, просто очень надо с этим разобраться, или подскажите как вывести информацию из двух таблиц и чтобы было проще сохранить изменения.
0
07.12.2015, 21:35
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
07.12.2015, 21:35
Помогаю со студенческими работами здесь

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

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

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

Сохранение изменений в БД при редактировании данных
Создал таблицу с помощью GridControl из комплекта Devexpress...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru