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

Строка удаляется только из DataGridView, но в БД (.mdb) остаётся

06.04.2012, 20:32. Показов 1457. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добрый вечер!
Знаю, что уже не раз задавался вопрос, но все равно никак не могу понять: как обновить базу .mdb. Мне надо удалить одну строку, выбранную пользователем в DataGridView. Пробовал по-разному:
1)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
string nk = EditTable.Rows[number].Cells[0].Value.ToString();//номер выделенной строки
               int k = int.Parse(nk);
                string q = "DELETE * FROM LibraryDataBase WHERE [Регистрационный номер] Like '"+k+"'";//строка запроса
                OleDbConnection con = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\DatabaseLibrary.mdb");
                OleDbDataAdapter da=new OleDbDataAdapter(q,con);
                da.Fill(databaseLibraryDataSet.LibraryDataBase);
                MessageBox.Show(databaseLibraryDataSet.HasChanges().ToString());
                EditTable.DataSource=databaseLibraryDataSet.LibraryDataBase;
                    
                try
                {
                    con.Open();
                }
                catch
                {
                    MessageBox.Show("Соединение не может быть открыто!", "Ошибка!");
                 }
                    libraryDataBaseTableAdapter.Update(databaseLibraryDataSet.LibraryDataBase);
 
                    con.Close();
Ошибки не выдаёт, но и БД не обновляет.
2)
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
int number = EditTable.CurrentRow.Index;//номер выделенной строки
                databaseLibraryDataSet.LibraryDataBase.Rows.RemoveAt(number);//удаление строки из DataSet
                databaseLibraryDataSet.LibraryDataBase.AcceptChanges();
                
                OleDbConnection con = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\DatabaseLibrary.mdb");               
                try
                {
                    con.Open();
                }
                catch { MessageBox.Show("Соединение не может быть открыто!", "Ошибка!"); }
                libraryDataBaseTableAdapter.Update(databaseLibraryDataSet.LibraryDataBase);
 
                con.Close();
Строка удаляется только из DataGridView, но в БД (.mdb) остаётся(((
Подскажите, пожалуйста, как исправить код. Заранее спасибо)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
06.04.2012, 20:32
Ответы с готовыми решениями:

Почему не удаляется единственная строка из DataGridView?
Объясните почему я не могу удалить методом this->dataGridView1->Rows->RemoveAt(0) единственную строку с индексом 0 на попытку подобного...

Удаляется следующая строка при удалении из dataGridView
Привет! Удаляю строку из dataGridView, но удаляется следующая строка. id присваивается следующей строки. Не понимаю почему так происходит. ...

Удаление строки из DataGridView: удаляется строка находящееся выше нужной
Все привет!!!! Из DataGridView плдключенном к Access удаляю строку вот этим способом. private void DeleteItem() { ...

2
1057 / 864 / 195
Регистрация: 31.03.2010
Сообщений: 2,521
06.04.2012, 22:03
Как работать с БД?
1. Создаем подключение
2. Открываем подключение
3. Создаем команду
4.
Без адаптера вызываем метод Command:
ExecuteNonQuery() - просто выполняет коменду(для обновления, например, или ставки)
ExecuteScalar() - возвращает значение 1-го поля 1-ой строки. Актуально если нужно вернуть только одно значение, напрмер, кол-во строк по условию.
ExecuteReader() - возвращает объект Reader который позволяет извлекать результат запроса построчно.

5. Если используем адаптер, то устанавливаем для него SelectCommand, UpdateCommmand, InsertCommand, DeleteCommand что необходимо или все вместе.
методы адаптера:
Fill(DataTable); - при помощи запроса Select получает данные и сохраняет их в объект DataTable, столбцы создаеются автоматически с именами, которые указаны в запросе. если таблица не пуста, то дописывает в нее данные дальше.
Update(DataTable) - проходит по всем строкам переданной таблицы и в зависимости jnот значения RowState(Modified, New, Deleted вроде так) строки выполняет соотвествующую команду. возвращает кол-во обработанных строк(с измененным статусом).

в вашем случае достаточно вместо адаптера использовать команду:

C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
string nk = EditTable.Rows[number].Cells[0].Value.ToString();//номер выделенной строки
               int k = int.Parse(nk);
                string q = "DELETE * FROM LibraryDataBase WHERE [Регистрационный номер] Like '"+k+"'";//строка запроса
                OleDbConnection con = new OleDbConnection("Provider=Microsoft.Jet.OLEDB.4.0;Data Source=|DataDirectory|\\DatabaseLibrary.mdb");
                OleDbCommand da=new OleDbCommand (q,con);
                    
                try
                {
                    con.Open();
                    da.ExecuteNonQuery();
                    MessageBox.Show(databaseLibraryDataSet.HasChanges().ToString());
                   int number = EditTable.CurrentRow.Index;//номер выделенной строки
                      databaseLibraryDataSet.LibraryDataBase.Rows.RemoveAt(number);
                }
                catch
                {
                    MessageBox.Show("Соединение не может быть открыто!", "Ошибка!");
                 }
                    
 
                    con.Close();
2
Кирим
06.04.2012, 22:30
Спасибо!!! Заработало!
А мне, наверно, надо побольше почитать по этой теме)
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
06.04.2012, 22:30
Помогаю со студенческими работами здесь

Обновление SQLite БД через DataGridView - обновляется только последняя строка
Добрый всем день. Возникла проблема в обновлении бд sqlite через dataGridView. Обновляется, только последняя строка, а при обновлении более...

Удаляется строка из БД
написал такой скриптик не пойму почему удаляет система из бд строку например в $datenorm записалась дата 23.11.2014 и система автоматически...

Удаляется не та строка
Привет! Полюбуйтесь на этот код, и скажите, пожалуйста, почему удаляется не текущая выделенная строка, а следующая за ней. ...

При очищении StringBuilder в нем остается пустая строка
Доброе время суток! При применении метода Clear: (Removes all characters from the current StringBuilder instance.) Все...

Не удаляется строка из файла
Подскажите. Почему у меня не удаляется опред.строка из файла? Айди строчки отправляется АЯКСом в файл. который должен удалить эту...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru