Форум программистов, компьютерный форум, киберфорум
C#: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.73/40: Рейтинг темы: голосов - 40, средняя оценка - 4.73
9 / 2 / 0
Регистрация: 18.09.2013
Сообщений: 98
SQLite

Загрузка в DataSet нескольких таблиц

04.02.2018, 23:31. Показов 8050. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте. У меня возникло несколько вопросов. Как известно DataSet может содержать несколько таблиц. Как загрузить эти таблицы в DataSet а затем в DataGridView и потом их же и сохранить с помощью SqlCommandBuilder (в таблицах только меняются значения в ячейках)? Вот пример:

............................

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
m_dbConn = new SQLiteConnection("Data Source=" + dbFileName + ";Version=3;");
m_dbConn.Open();
m_sqlCmd.Connection = m_dbConn;
 
String sqlQuery;
 
sqlQuery = "SELECT * FROM table1; SELECT * FROM table2; SELECT * FROM table3";
adapter = new SQLiteDataAdapter(sqlQuery, m_dbConn);
adapter.Fill(dSet);
 
dataGridView1.DataSource = dSet.Tables[0];
dataGridView1.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
dataGridView1.Visible = true;
dataGridView1.Columns[0].Visible = false;
 
dataGridView2.DataSource = dSet.Tables[1];
dataGridView2.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
dataGridView2.Visible = true;
dataGridView2.Columns[0].Visible = false;
 
dataGridView3.DataSource = dSet.Tables[2];
dataGridView3.AutoSizeColumnsMode = DataGridViewAutoSizeColumnsMode.Fill;
dataGridView3.Visible = true;
dataGridView3.Columns[0].Visible = false;
 
m_dbConn.Close();

Обновление в бд:
C#
1
2
SQLiteCommandBuilder rr = new SQLiteCommandBuilder(adapter);
adapter.Update(dSet);
или:
C#
1
2
3
adapter.Update(dSet.Tables[0]);
adapter.Update(dSet.Tables[1]);
adapter.Update(dSet.Tables[2]);
В данной вариации кода все таблицы загружаются и корректно отображаются во всех datagridview. Однако данные сохраняются только в пером варианте, и только в первую таблицу. Во втором варианте получаю ошибку времени исполнения: System.Data.DBConcurrencyException: "Нарушение параллелизма: UpdateCommand затронула 0 из ожидаемых 1 записей."
Как вариант решения проблемы - для каждой таблицы свое соединение, свой адаптер и свой датасет. Но это похоже на костыль. Собственно вопрос, как правильно сделать сохранение DataSet, содержащего 3 и более таблиц. Спасибр
0
Лучшие ответы (1)
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
04.02.2018, 23:31
Ответы с готовыми решениями:

Асинхронное загрузка таблиц в DataSet
Можно ли реализовать глобальную и асинхронную загрузку таблиц в DataSet ? Т.е Мы подключаемся к БД и сразу начинаем загружать все таблицы...

Неоднократная загрузка повторных таблиц в DataSet
Доброго времени суток, Господа. Есть база данных от Visual Fox Pro. Нужно с ней работать из программы на C#. Создал два класса: ...

Загрузка нескольких вложенных DataSet-ов
Приветствую всех! Обращаюсь в надежде, что местные гуру подскажут решение. Сам я уже запарился его искать. Речь идёт о DataSnap....

5
 Аватар для Козадоев
165 / 155 / 33
Регистрация: 05.03.2013
Сообщений: 879
05.02.2018, 07:50
Цитата Сообщение от sub-r-outine Посмотреть сообщение
"Нарушение параллелизма: UpdateCommand затронула 0 из ожидаемых 1 записей."
Так бывает, когда запись уже изменена, а в вашем наборе данных данные устарели. (вы уже где то сохранили данные)
Цитата Сообщение от sub-r-outine Посмотреть сообщение
Как вариант решения проблемы - для каждой таблицы свое соединение, свой адаптер и свой датасет.
Вы что то делаете неправильно. Все отлично сохраняется методом Update. Если таблицы связанны ключами, то нужно соблюдать определенный порядок.
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
05.02.2018, 09:22
Для того, чтобы адаптер обновлял данные сам, нужно несколько условий соблюдать.
1. У таблицы должен быть primary key
2. Адаптер должен видеть этот ключ у себя
3. У таблиц не должно быть связей по внешним ключам
Если эти правила не соблюдаются - то могут возникнуть проблемы как у Вас. И тогда лучше писать самостоятельно все 3 комманды модификации таблиц. На каждую таблицу.
0
9 / 2 / 0
Регистрация: 18.09.2013
Сообщений: 98
05.02.2018, 20:00  [ТС]
Козадоев, hoolygan, спасибо за ответы. Нарушение параллелизма возникает не зависимо от того редактирую данные в DGV или через dataset. Таблицы не зависимы, каждые имеют первичный ключ, названия столбцов у всех таблиц разные. Насчет того, видит ли адаптер первичный ключ - не знаю как проверить.
0
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
05.02.2018, 21:58
Проверить легко. У каждой из таблиц есть констрейнты. Одним из них и будет primary key. Буду за компом - посмотрю детальней, так сходу не помню.
0
785 / 616 / 273
Регистрация: 04.08.2015
Сообщений: 1,713
06.02.2018, 09:35
Лучший ответ Сообщение было отмечено sub-r-outine как решение

Решение

Цитата Сообщение от sub-r-outine Посмотреть сообщение
C#
1
2
sqlQuery = "SELECT * FROM table1; SELECT * FROM table2; SELECT * FROM table3";
adapter = new SQLiteDataAdapter(sqlQuery, m_dbConn);
Адаптер не может быть создан сразу для 3-х таблиц. Он создается только для первой.
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.02.2018, 09:35
Помогаю со студенческими работами здесь

Изменение запроса в зависимости от выбранных строк в нескольких DbGrid (в SQL получить значения из нескольких DataSet)
Здравствуйте. Есть таблицы и компоненты: Tbl_authors – Таблица авторов. С ней связаны компоненты: - ADOTable_authors, -...

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

Обновление таблиц в DataSet
Здравствуйте! Пишу БД. Столкнулся с такой проблемой: В БД Access 2007 имеется несколько связанных таблиц - таблица Страны, таблица...

Произведение таблиц из dataset
товарищи, подскажите как быть: засунул в датасет две таблицы из БД, нужно получить произведение этих двух даттейблов в третью, вывести ее в...

Изменение порядка таблиц в dataSet
В dataSet добавлено много таблиц. Добавлялись изначально в произвольном порядке, но появилась задача выгружать таблицы из dataSet в xml...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера 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. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru