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

Вывести MessageBox за цикл

01.06.2022, 14:22. Показов 835. Ответов 3

Студворк — интернет-сервис помощи студентам
Есть datagridview1, в котором занесены данные из базы данных, я сортирую эту таблицу по 4-му столбцу(по индексу). Задача в том, что мне нужно вывести MessageBox, если выбранная пользователем дата не соответсвует тому, что есть в таблице. Вот пример моего кода, где MessageBox в цикле, из-за чего появляется не один раз. Нужно как-то вынести его за цикл)
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
for (int i = 0; i < dataGridView1.RowCount; i++)
            {
                if (dateTimePicker1 == dataGridView1.Rows[i].Cells[4].Value)
                {
                    using (SqlConnection sql = new SqlConnection(connectionString))
                    {
 
                        sql.Open();
                        SqlDataAdapter dataAdapter = new SqlDataAdapter("SELECT Назва, Жанр, Початок, Тривалість, Дата FROM TableKino WHERE Дата = @dateSort ORDER BY Дата DESC", sql);
                        dataAdapter.SelectCommand.Parameters.AddWithValue("@dateSort", dateTimePicker1.Value.Date);
 
                        SqlCommandBuilder builder = new SqlCommandBuilder(dataAdapter);
                        DataTable dataTable = new DataTable();
                        dataAdapter.Fill(dataTable);
                        BindingSource binding = new BindingSource();
                        binding.DataSource = dataTable;
 
                        dataGridView1.DataSource = dataTable;
                    }
                }
 
                if (dateTimePicker1 != dataGridView1.Rows[i].Cells[4].Value)
                {
                    MessageBox.Show("Выберите другую дату");
                }
            }
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
01.06.2022, 14:22
Ответы с готовыми решениями:

Как сделать повторяющийся цикл в messagebox?
как сделать повторяющийся цикл в messagebox? пример на картинке; мой обычный код: int one = MessageBox(NULL, L&quot; у тебя есть...

Вычислить и вывести сумму чётных целых чисел в интервале от 1 до n: 1) цикл «ДО» 2) цикл «ПОКА» 3) цикл «ДЛЯ»
Вычислить и вывести сумму чётных целых чисел в интервале от 1 до n: 1. цикл «ДО» 2. цикл «ПОКА» 3. цикл «ДЛЯ»

Как вывести MessageBox
Работаю в VS C++. Создал проект Windows Forms, поместил кнопочку, вопрос: что нужно написать что бы по клику выводился MessageBox?

3
 Аватар для ViterAlex
8952 / 4864 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
01.06.2022, 14:29
daria_shla, у тебя неверный подход. Если данные уже загружены, то фильтровать их нужно в BindingSource. Выложи проект, можно без базы
0
1 / 1 / 0
Регистрация: 19.11.2021
Сообщений: 89
01.06.2022, 14:41  [ТС]
ViterAlex, а через if в таком варианте никак не сделать?
0
 Аватар для ViterAlex
8952 / 4864 / 1886
Регистрация: 11.02.2013
Сообщений: 10,246
01.06.2022, 14:46
Лучший ответ Сообщение было отмечено daria_shla как решение

Решение

Ну какой if. Зачем этот огород? Тут цикл вообще не нужен. Делаем запрос в базу. Если он приходит пустой, значит выводим сообщение
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
using (SqlConnection sql = new SqlConnection(connectionString))
{
 
    sql.Open();
    SqlDataAdapter dataAdapter = new SqlDataAdapter("SELECT Назва, Жанр, Початок, Тривалість, Дата FROM TableKino WHERE Дата = @dateSort ORDER BY Дата DESC", sql);
    dataAdapter.SelectCommand.Parameters.AddWithValue("@dateSort", dateTimePicker1.Value.Date);
 
    SqlCommandBuilder builder = new SqlCommandBuilder(dataAdapter);
    DataTable dataTable = new DataTable();
    dataAdapter.Fill(dataTable);
    BindingSource binding = new BindingSource();
    binding.DataSource = dataTable;
 
    dataGridView1.DataSource = dataTable;
    if (!dataTable.HasRows)
    {
        MessageBox.Show("Выберите другую дату");
    }
}
без цикла.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
01.06.2022, 14:46
Помогаю со студенческими работами здесь

Вывести MessageBox с паузой
Доброго времени суток, товарищи! Недавно возникла проблемка с выводом MessageBox. Ниже приведен код программы. Программа должна работать...

Вывести символ в MessageBox
Как это можно сделать ? Пишу так: char a='a'; MessageBox(NULL,(LPCWSTR)a,L&quot;Окно&quot;, MB_OK); но это не правильно как...

Вывести массив в MessageBox
Сортирую массив DWORD на masm`e для Visual Studio с помощью процедуры . Вопрос в том чтоб как-то вывести его в MessageBoxA@16. Помогите кто...

Заменить символ 'l' на '1' и вывести строку в MessageBox
Я совсем новичок в Ассемблере, но задали лабу, никуда от нее не деться. Имеется строка, которая заносится в регистр esi. Все символы 'l'...

Два раза открывается MessageBox.Show после второго вызова MessageBox
Здравствуйте! Подскажите пожалуйста... Мне вот надо было сделать диалоговое окно для ввода данных для бегущей строки. Кроме этого,...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
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),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
Как дизайн сайта влияет на конверсию: 7 решений, которые реально повышают заявки
Neotwalker 08.03.2026
Многие до сих пор воспринимают дизайн сайта как “красивую оболочку”. На практике всё иначе: дизайн напрямую влияет на то, оставит человек заявку или уйдёт через несколько секунд. Даже если у вас. . .
Модульная разработка через nuget packages
DevAlt 07.03.2026
Сложившийся в . Net-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru