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

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

07.10.2011, 13:09. Показов 1700. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а привычная функция main(). . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
http://iceja.net/ математические сервисы
iceja 20.01.2026
Обновила свой сайт http:/ / iceja. net/ , приделала Fast Fourier Transform экстраполяцию сигналов. Однако предсказывает далеко не каждый сигнал (см ограничения http:/ / iceja. net/ fourier/ docs ). Также. . .
http://iceja.net/ сервер решения полиномов
iceja 18.01.2026
Выкатила http:/ / iceja. net/ сервер решения полиномов (находит действительные корни полиномов методом Штурма). На сайте документация по API, но скажу прямо VPS слабенький и 200 000 полиномов. . .
Расчёт переходных процессов в цепи постоянного тока
igorrr37 16.01.2026
/ * Дана цепь(не выше 3-го порядка) постоянного тока с элементами R, L, C, k(ключ), U, E, J. Программа находит переходные токи и напряжения на элементах схемы классическим методом(1 и 2 з-ны. . .
Восстановить юзерскрипты Greasemonkey из бэкапа браузера
damix 15.01.2026
Если восстановить из бэкапа профиль Firefox после переустановки винды, то список юзерскриптов в Greasemonkey будет пустым. Но восстановить их можно так. Для этого понадобится консольная утилита. . .
Сукцессия микоризы: основная теория в виде двух уравнений.
anaschu 11.01.2026
https:/ / rutube. ru/ video/ 7a537f578d808e67a3c6fd818a44a5c4/
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru