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

Удаление строки из DataGridView субд SQLite

05.03.2017, 18:41. Показов 2807. Ответов 6
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые программисты, возникла проблема. Простите за корявый русский, башня уже вяло соображает..)

Имеется БД SQLite, из нее необходимо удалить строку из DataGridView с последующим заполнением DataGridView этой же бд только без строки. Вроде все идеально, строки добавляю, удаляю, но после того как строку удаляю в таблицу заполняется только последняя строка базы. Причем я открывал в редакторе эту бд, все как надо строки есть кроме удаленной. То есть про заполнении таблицы у меня добавляется одна строка, а в реале там все необходимые строки есть. Заполнение происходит через одну и ту же функцию, поэтому я не знаю в чем у меня проблема. Файлы и листинги прилагаю.

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
//удаление
        private void button2_Click(object sender, EventArgs e)   // Удаление
        {
            int a = dataGridView1.CurrentRow.Index; // Выделенная строка в таблице
            int id_table = Convert.ToInt32(dataGridView1.Rows[a].Cells[3].Value);
            
 
            SQLiteConnection conn = new SQLiteConnection("Data Source=filename.db; Version=3;");
            
                conn.Open();
 
            SQLiteCommand cmd = conn.CreateCommand();  // создаем обьект cmd
 
            string sql_delete = "DELETE FROM Keys WHERE id = '" + id_table + "';";  // Команда на удаление //Ошибка при значении "NULL", сделать исключение
 
            cmd.CommandText = sql_delete;
 
            try
            {
                cmd.ExecuteNonQuery(); // выполняем КОМАНДУ удаления, проверка на ошибку
            }
            catch (SQLiteException ex)
            {
                Console.WriteLine(ex.Message);
            }
            
            dataGridView1.Rows.Clear();
           
 
            conn.Close();
            
            vtablicy(); // Обновляем таблицу таблицу
        }
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
 
 
        // Заполнение таблицы
        public void vtablicy()
        {
            SQLiteConnection conn = new SQLiteConnection("Data Source=filename.db; Version=3;");
            SQLiteCommand cmd = conn.CreateCommand();
 
 
 
 
            try
            {
                conn.Open();
            }
            catch (SQLiteException ex)
            {
                Console.WriteLine(ex.Message);
            }
 
 
            cmd.CommandText = "SELECT id, Names, Serial, Tirazh from Keys";
            try
            {
                SQLiteDataReader r = cmd.ExecuteReader();   // ридер из класса cmd
                string n, s, t, id;                 // пустая строка
                int i = dataGridView1.Rows.Add();
                
                while (r.Read())                            // пока ридер будет читать строки, то есть пока не кончится БД
                {
                    n = r["Names"] + "";    // ХЗ зачем + ""
                    s = r["Serial"] + "";
                    t = r["Tirazh"] + "";
                    id = r ["id"] + "";
 
 
                    
                    dataGridView1.Rows[i].Cells[0].Value = n;
                    dataGridView1.Rows[i].Cells[1].Value = s;
                    dataGridView1.Rows[i].Cells[2].Value = t;
                    dataGridView1.Rows[i].Cells[3].Value = id; // в инвизе
                    
                }
                i = 0;
                r.Close();  // уничтожить его когда закончатся строки
            }
            catch (SQLiteException ex)
            {
                string Error = ex.Message;
                MessageBox.Show(Error);
            }
 
 
            conn.Dispose();
        }
Миниатюры
Удаление строки из DataGridView субд SQLite   Удаление строки из DataGridView субд SQLite   Удаление строки из DataGridView субд SQLite  

0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
05.03.2017, 18:41
Ответы с готовыми решениями:

Удаление строки из БД Sqlite
Добрый вечер. Хочу удалить строку по имени. Что то не получается. Помогите пожалуйста. public class DataBaseHelper extends...

SQLite получить все строки из БД и добавить их в уже имеющуюся DataGridView
Предположим на форму уже имеется DGV настроенная как надо, вот и вопрос возникает , как иначе получить все строки и разом впихнуть их в...

Как реализовать удаление строки по истечении времени в SQLite?
БД содержит информацию о клиентах платной автостоянки (ФИО, телефон, номер машины, время стоянки в минутах). Как реализовать удаление...

6
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 74
05.03.2017, 18:43  [ТС]
а вот в редакторе, ну то как раз что я говорил, 2 строки без первой удаленной.
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 74
05.03.2017, 18:43  [ТС]
0
 Аватар для Aferuga
644 / 528 / 324
Регистрация: 20.05.2015
Сообщений: 1,469
05.03.2017, 19:04
что это за бред?
C#
1
int i = dataGridView1.Rows.Add();
и почему если уж на то пошло i в цикле не меняется?
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 74
05.03.2017, 19:18  [ТС]
Вроде инкремент был, кажется я при поиске ошибки его удалил, приду домой проверю... А даже если с ним не будет работать в чем может быть ошибка?
0
 Аватар для Aferuga
644 / 528 / 324
Регистрация: 20.05.2015
Сообщений: 1,469
05.03.2017, 19:33
Лучший ответ Сообщение было отмечено Markell как решение

Решение

ну ошибка скорее всего именно в нем, подходит идеально.

Добавлено через 7 минут
Хотя на 3 строке он вам выдаст ошибку мол строк в гриде не хватает
В идеале должно быть как-то так:
C#
1
2
3
4
5
6
7
while (r.Read())                            // пока ридер будет читать строки, то есть пока не кончится БД
                {
                    dataGridView1.Rows.Add( r["Names"],   
                     r["Serial"],
                     r["Tirazh"],
                     r["id"]);
}
0
0 / 0 / 0
Регистрация: 17.11.2015
Сообщений: 74
05.03.2017, 23:25  [ТС]
Спасибо и еще очистка, потому что он все данные тогда заново добавляет , а старые не старает))

C#
1
2
3
4
5
6
7
8
 dataGridView1.Rows.Clear();
               while (r.Read())                            
                {
                    dataGridView1.Rows.Add(r["Names"] ,    
                    r["Serial"],
                    r["Tirazh"] ,
                    r["id"]);
                 }
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
05.03.2017, 23:25
Помогаю со студенческими работами здесь

SQLite запретить удаление строки, если есть ссылки на нее
Здравствуйте! Как создать таблицы, чтобы при попытке удаления строк в одной из них операция проваливалась, если на нее есть ссылка из...

Как запретить удаление строки в DataGridView, если пользователь не выбрал ни одной строки?
Здравствуйте! У меня есть datagridview и кнопка удаления записи на форме. Данные в datagridview попадают из таблицы базы данных...

Delphi и СУБД SQLite Studio
Добрый времени суток. Предметная область ЗАГС. Есть 3 таблице(показана на логической модели данных). Проблема в том, что при...

Удаление строки из DataGridView
На форме два DataGridView. В первом 7 столбцов, а во втором 10 столбцов. Количество строк в них тоже разное. Как сделать, чтобы при...

Удаление Строки из DataGridView
Проблема заключается в следующем я написал код но он почему-то удаляет только первую строку при попытке удаления второй третей и тд...


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Загрузка 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 , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru