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

Заполнение dataGridView с проверкой try catch

06.06.2019, 12:23. Показов 2196. Ответов 1

Студворк — интернет-сервис помощи студентам
Как реализовать проверку "try catch" при заполнении данными dataGridView из базы данных.
Ввожу данные в TextBox1 и при нажатии кнопки "Поиск", выполняю поиск по Id в базе данных (SELECT * FROM User WHERE Id), результат поиска заношу в dataGridView1, а как вывести сообщение, что данные не найдены (отсутствуют записи в таблице), если они не записались в dataGridView1. Допустим если ищу id 5 и его нету (нету всей строки, или удалили данные из БД), то вывести сообщение об ошибке (данные не найдены).

Таблица:User;
Колонки таблицы: Id, Name, Gorod, Phone

Добавлено через 2 часа 8 минут
"корявенький код" но работает
в label38 выводяться сообщения
textBox31 проверяеться на пустоту
в dataGridView4 заносяться данные из бд (в бд 7 колонок)

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
56
57
58
{
            if (label38.Visible)
                label38.Visible = false;
            if (!string.IsNullOrEmpty(textBox31.Text) && !string.IsNullOrWhiteSpace(textBox31.Text))
            {
                SqlCommand command = new SqlCommand("SELECT * FROM [Instryktash] WHERE [Id]=@Id", SqlConnection);
                    command.Parameters.AddWithValue("Id", textBox31.Text);
                    await command.ExecuteNonQueryAsync();
                    textBox31.Text = "";
                    textBox31.Clear();
                    SqlDataAdapter sda = new SqlDataAdapter(command);
                   DataTable dtb2 = new DataTable();
                    sda.Fill(dtb2);
                    if (dtb2.Rows.Count == 1)
                    {                        
                        dataGridView4.Rows.Clear();
                        SqlDataReader reader = await command.ExecuteReaderAsync();
                        try
                        {                         
                        List<string[]> data = new List<string[]>();
                        while (await reader.ReadAsync())
                        {
                            data.Add(new string[7]);
                            data[data.Count - 1][0] = reader[0].ToString();
                            data[data.Count - 1][1] = reader[1].ToString();
                            data[data.Count - 1][2] = reader[2].ToString();
                            data[data.Count - 1][3] = reader[3].ToString();
                            data[data.Count - 1][4] = reader[4].ToString();
                            data[data.Count - 1][5] = reader[5].ToString();
                            data[data.Count - 1][6] = reader[6].ToString();
                        }
                        reader.Close();
                        foreach (string[] s in data)
                            dataGridView4.Rows.Add(s);
                        }
                        catch (Exception ex)
                        {
                            MessageBox.Show(ex.Message.ToString(), ex.Source.ToString(), MessageBoxButtons.OK, MessageBoxIcon.Error);
                        }
                        finally
                        {
                            if (reader != null)
                            reader.Close();
                        }
                        label38.Visible = true;
                        label38.Text = "Данные успешно найдены";
                        }
                    else
                    {
                        MessageBox.Show("Не правильный Id");
                    }
                }
            else
            {
                label38.Visible = true;
                label38.Text = "Поле ID должно быть заполненым";
            }
        }
тему можно закрывать, так как немного понял как оно работает.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
06.06.2019, 12:23
Ответы с готовыми решениями:

Одномерный массив с проверкой try-catch
Добрый день. Недавно началось обучение C#. Дали задание: &quot;Задан одномерный массив. Сколько раз встречается пара элементов, в которой один...

Задача на заполнение одномерного массива с консоли с проверкой значений
Доброго времени суток! Есть проблема с решением задачи следующего толка: Есть произвольный студент, необходимо ввести его оценки с консоли...

Значение Null в datagridview вызывает исключение. Не получается использовать Try-Catch
Доброго времени суток. Чет уже котелок совсем не варит. после прохождения всех строк в DGV ...

1
Эксперт .NET
6691 / 4102 / 1607
Регистрация: 09.05.2015
Сообщений: 9,575
06.06.2019, 12:37
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
                        List<string[]> data = new List<string[]>();
                        while (await reader.ReadAsync())
                        {
                            data.Add(new string[7]);
                            data[data.Count - 1][0] = reader[0].ToString();
                            data[data.Count - 1][1] = reader[1].ToString();
                            data[data.Count - 1][2] = reader[2].ToString();
                            data[data.Count - 1][3] = reader[3].ToString();
                            data[data.Count - 1][4] = reader[4].ToString();
                            data[data.Count - 1][5] = reader[5].ToString();
                            data[data.Count - 1][6] = reader[6].ToString();
                        }
                        reader.Close();
                        foreach (string[] s in data)
                            dataGridView4.Rows.Add(s);
                        }
->
C#
1
2
3
4
5
                        while (await reader.ReadAsync())
                        {
                            dataGridView4.Rows.Add(new string[] { reader[0].ToString(), reader[1].ToString(), reader[2].ToString(), reader[3].ToString(), reader[4].ToString(), reader[5].ToString(), reader[6].ToString() });
                        }
                        reader.Close();
Зачем тут SqlDataAdapter, DataTable и 2 раза запрос делается тоже не понятно... Есть же SqlDataReader.HasRows...

C#
1
2
                    textBox31.Text = "";
                    textBox31.Clear();
Это типа чтобы наверняка?

Добавлено через 3 минуты
C#
1
if (!string.IsNullOrEmpty(textBox31.Text) && !string.IsNullOrWhiteSpace(textBox31.Text))
Достаточно одной проверки на string.IsNullOrWhiteSpace...
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
06.06.2019, 12:37
Помогаю со студенческими работами здесь

Конструкция try catch в цикле while. Зацикливается блок catch
Здравствуйте. Столкнулся с проблемой: при попытке запихнуть в цикл конструкцию try catch - зацикливается часть, расположенная в блоке...

Заполнение dataGridView
Есть dataGridView состоит из 3 столбцов, необходимо заполнить рандомными значениями, кол-во которых задается из textBox ...

DataGridView Заполнение
Помогите решить вопрос. Вообщем у меня такая проблема есть программа при ее запуске в datagridview выводятся цифры за место слов как...

Заполнение dataGridView
Как начать заполнение dataGridView со второй ячейки? К примеру есть две ячейки H и K H | Заполнение начинается со второй ячейки первой...

Заполнение dataGridView
Подскажите пожалуйста,как заполнить dataGridView У меня есть код private void bolshe(double x1, double x2) { ...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
1С: Программный отбор элементов справочника по группе
Maks 22.03.2026
Установка программного отбора элементов справочника "Номенклатура" из модуля формы документа. В качестве фильтра для отбора справочника служит группа номенклатуры. Отбор по наименованию группы. . .
Как я обхитрил таблицу Word
Alexander-7 21.03.2026
Когда мигает курсор у внешнего края таблицы, и нам надо перейти на новую строку, а при нажатии Enter создается новый ряд таблицы с ячейками, то мы вместо нервных нажатий Энтеров мы пишем любые буквы. . .
Krabik - рыболовный бот для WoW 3.3.5a
AmbA 21.03.2026
без регистрации и смс. Это не торговля, приложение не содержит рекламы. Выполняет свою непосредственную задачу - автоматизацию рыбалки в WoW - и ничего более. Однако если админы будут против -. . .
1С: Программный отбор элементов справочника по значению перечисления
Maks 21.03.2026
Установка программного отбора элементов справочника "Сотрудники" из модуля формы документа. В качестве фильтра для отбора служит значение перечислений. / / Событие "НачалоВыбора" реквизита на форме. . .
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru