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

Обновления измененной информацию из нескольких не связанных таблиц в бд

26.11.2015, 17:25. Показов 625. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый день, передо мной стояла задача при нажатии на кнопку вывести в datagridview информацию из таблиц, а с каких именно таблиц брать информацию зависит от того что выбрано в combobox. Это я реализовать смог, не знаю на сколько корректно составил код (так как я новичок и норм информации найти не смог делал сам), но все работает, но теперь нужно чтобы после редактирования, при нажатии кнопки информация сохранилась в базе данных, когда пытаюсь это сделать выскакивает такая ошибка:

Для обновления требуется действительный UpdateCommand при передаче коллекции DataRow с измененными строками.

И место где она берется:
C#
1
dbAdapter1.Update(dataTable);
Я так понял что надо что-то сделать с UpdateCommand, но я не могу понять что и как, помогите пожалуйста. Вот код:
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
80
81
82
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)
        {
 
 
            string i, ychni, predmet, a, b;
            b = "Учні" + comboBox3.Text + "клас";
            ychni = b; ;
            a = comboBox2.Text + comboBox3.Text;
            predmet = a;
            i = ychni+","+predmet;
 
            dbAdapter1 = new OleDbDataAdapter(@"SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM " +i, dbCon);
            dataTable = new DataTable();
            dbAdapter1.Fill(dataTable);
            dataGridView2.DataSource = dataTable;
 
 
           
 
        }
 
        private void button1_Click(object sender, EventArgs e)
        {
 
            dbAdapter1.Update(dataTable);
 
        }
    }
}
Вот сам проект
Вложения
Тип файла: rar Архив WinRAR.rar (266.0 Кб, 1 просмотров)
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
26.11.2015, 17:25
Ответы с готовыми решениями:

Выборка из нескольких связанных таблиц
Как выбрать значения из связанной таблицы понятно. А как выбрать значения из нескольких связанных таблиц? Есть таблица со списком...

Выборка из нескольких таблиц, связанных по ID
Здравствуйте! В инете ничего толкового не нашёл в ответ на свой вопрос, поэтому задаю вопрос здесь. Есть 3 таблицы (к примеру): section...

Как вывести информацию из двух связанных по ID таблиц
Но если во второй таблице три поля, в котором присутствую ID из первой таблице!!!! Я сколько не бился, не получается! Максимум что...

2
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
26.11.2015, 20:44  [ТС]
Пожалуйста помогите , я новичок в этом деле , для вас это пару минут займет. Я сам хотел но ничего не получается.
0
2 / 2 / 3
Регистрация: 17.09.2013
Сообщений: 279
27.11.2015, 00:28  [ТС]
я пытаюсь что-то такое делать
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
   string i, ychni, predmet, a, b;
            b = "Учні" + comboBox3.Text + "клас";
            ychni = b; ;
            a = comboBox2.Text + comboBox3.Text;
            predmet = a;
            i = ychni + "," + predmet;
            
            dbAdapter1 = new OleDbDataAdapter("SELECT Прізвище, Імя, [Оцінка за 1 см], [Оцінка за 2 см], Річна FROM " + i, 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
27.11.2015, 00:28
Помогаю со студенческими работами здесь

Вывести всю информацию в том числе из связанных таблиц
База Данных имеет '3'-и таблицы, в каждой из них есть свой 'id', с разного рода описанием услуг и прочего. Это все связано в одной...

Microsoft report viewer , как репортировать информацию из связанных таблиц?
здравствуйте Cкажите пожалуйста как репортировать информацию из связанных таблиц? допустим у меня в базе данных есть 2 связанные...

Объединение нескольких связанных импортированных таблиц в 1 запрос
Требуется Ваша помощь, друзья!) У меня есть 15 таблиц по 15ти отделам, с одинаковыми шапками. Мне необходимо объединить их в одну, но...

Удаление данных из нескольких связанных таблиц одновременно
Ситуация такова,работа с БД,добавление палей в три таблицы(один к одному),изменение данных полей,удаление Добавление и изменение работают...

Как при выборе строки в DataGridView вывести информацию из связанных таблиц
Здравствуйте. Подскажите пожалуйста. Имеется база данных в которой находятся 5 связанных между собой таблиц. Имеется программа, в которой...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Модульный подход на примере 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 На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip Сканируйте QR-код на мобильном и вы увидите, что появится джойстик для управления главным героем. . . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru