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

Как добавить сохраненную в БД запись в DataSet

07.10.2011, 13:09. Показов 1728. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Здравствуйте!

Разрабатываю приложение в среде VS, язык С#, встраиваемая база данных Firebird Embedded.
Для работы с базой применяю OleDbCommand (SelectCommand, UpdateCommand, InsertCommand, DeleteCommand). Сформировав, например, запрос Select вызываю следующий код для заполнения DataTable в DataSet:

C#
1
2
3
4
5
6
7
8
da.SelectCommand.Connection.Open();
da.SelectCommand.Transaction = da.SelectCommand.Connection.BeginTransaction();
da.SelectCommand.ExecuteNonQuery();
if(this.dataSet.Tables.Contains(this.TableName))
   this.dataSet.Tables[this.TableName].Clear();
da.Fill(this.dataSet, this.TableName);
da.SelectCommand.Transaction.Commit();
da.SelectCommand.Connection.Close();
После чего отображаю данные в DataGridView.

Вопрос:
Если выполняю команды Insert или Update (т.е. добавляю новую запись или обновляю в БД уже существующую) каким образом:
1) в случае выполнения команды Insert добавить эту (созданную в БД) запись в DataSet, чтобы данные в БД соответствовали данным, отображаемым в DataGridView
2) в случае выполнения команды Update изменить требуемую запись в DataSet, чтобы измененные данные тут же отобразились в DataGridView.
На данный момент приходится просто обновлять все данные (после выполнения Insert или Update), т.е. делать запрос Select и заново заполнять DataSet всеми данными, хотя была добавлена или обновлена просто одна запись. Подскажите, пожалуйста, каким образом можно обновить или добавить только требуемую запись.
Спасибо.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
07.10.2011, 13:09
Ответы с готовыми решениями:

Как добавить дату из dateTimePicker в dataset
Здравствуйте.Нужна помощь срочно... у меня такая проблема, есть несколько textbox-сов и несколько dateTimePicker. Данные из textbox...

Как программно добавить все таблицы из БД в DataSet
Подскажите пожалуйста, как программно добавить все таблицы из БД в DataSet

Как найти в DataSet. запись с определённым значением?
Как найти в DataSet. запись с определённым значением? не просто перебирая весь DataSet, а воспользоваться каким-нить методом можно...

4
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
07.10.2011, 17:10
IDataAdapter.Update - метод
0
0 / 0 / 0
Регистрация: 06.10.2011
Сообщений: 9
07.10.2011, 20:14  [ТС]
Метод IDataAdapter.Update не подходит в данном случае, т.к. у меня обратная ситуация - данные уже сохранены в БД и их необходимо обновить в DataSet. А метод Update() сохраняет в БД данные из DataSet
0
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
07.10.2011, 20:23
.Fill
0
0 / 0 / 0
Регистрация: 06.10.2011
Сообщений: 9
07.10.2011, 22:25  [ТС]
У меня сейчас такой вариант и есть - с помощью Fill приходится обновлять все записи, даже те которые без изменений (добавлена или изменена только одна, а загружаю сейчас все). Если данных много, то это будет сказываться на производительности
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
07.10.2011, 22:25
Помогаю со студенческими работами здесь

Как добавить строку в таблицу объекта DataSet и сохранить её в БД Access?
Помогите. Создал БД в Access. Считал необходимые таблицы. Заполнил ими DataSet. Теперь могу изменять значения полей в таблицах и сохранять...

Как открыть базу, сохранённую в старой версии Access?
Есть БД я ее создавал в 2003, после в 2010 она не открывалась . и я чего то к не делал.все что можно преоброзовал и под всем...

Делаю игру в Unity3D. Как использовать сохраненную библиотеку класов в VS?
открываю решение, запускаю на дебаг - выдает собщение, что это библиотека класов. возможно ли изменить этот проект - добавить меню в...

Четыре кнопки на форме: добавить запись, удалить запись, закрыть, найти запись
Private Sub КнопкаДобавитьЗапись_Click() On Error GoTo Err_КнопкаДобавитьЗапись_Click DoCmd.GoToRecord , , acNewRec ...

Как открыть сохраненную html ссылку браузера через эмулятор терминала?
Здравствуйте. В каталоге $HOME/'Рабочий стол'/'Ссылки браузера' сохранена ссылка браузера Openmefromterminal.html. В ходе моего...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита "ПричинаСписания". . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru