|
62 / 6 / 1
Регистрация: 09.09.2012
Сообщений: 137
|
|||||||||||||||||||||||||||||||
Фильтрация данных в DataGridView в зависимости от значения в txtBox по событию TextChanged12.03.2019, 22:45. Показов 3285. Ответов 7
Здравствуйте!
Имеется форма с двумя TextBox (textBox1 и textBox2), а также DataGridView (dgvAll) в классе DAL содержится информация о строке подключения и ArrayList для отображения в dgvAll
Пока смог реализовать только вот таким способом: для этого отказался в основной форме от класса DAL и поправил код основной формы подписал textBox1 и textBox2 на одно и то же событие TextChanged
Возникла проблема, помогите решить в некоторых ячейках, по которым идет фильтрация (tbl_Expert.Expert), ничего не содержится, поэтому запрос
Помогите пожалуйста исправить запрос.
0
|
|||||||||||||||||||||||||||||||
| 12.03.2019, 22:45 | |
|
Ответы с готовыми решениями:
7
Фильтрация в combobox в зависимости от выбора значения Фильтрация данных в зависимости от выбора в ComboBox Фильтрация данных в DGV в зависимости от выбора в ComboBox |
|
|
|
| 12.03.2019, 23:22 | |
|
Kaliostro82,
Во-первых, не вставляйте параметры непосредственно в SQL запросы. Это приводит к ошибочным запросам в лучшем случае, и к взлому БД в худшем. Используйте SqlParameter. Во-вторых, раз уж вы уже имеете полностью загруженную выборку, то делать новую выборку в БД при каждом изменении текстбокса - долго и не рационально. Нужно фильтровать уже загруженную выборку. Для этого 1) Замените ArrayList (который кстати уже устарел лет как 15, вместо него - List<T>) на связку DataTable + DataView. 2) В грид передавайте DataView в качестве источника данных DataSource. 3) Фильтрацию проводите в DataView.
0
|
|
|
62 / 6 / 1
Регистрация: 09.09.2012
Сообщений: 137
|
||||||
| 13.03.2019, 12:15 [ТС] | ||||||
|
Storm23,
Я учусь на чужих примерах, поэтому и использую устаревшие конструкции, с этим уж ничего не поделаешь. Но я готов, и с удовольствием, прислушиваться к Вашему мнению и изменить код, но мне нужна Ваша помощь. Напишите пожалуйста примеры по пунктам, о которых Вы говорите. Добавлено через 4 минуты У меня получается пока так
Если я правильно понимаю, то я привел пример пункта 2 о котором Вы сказали. Правильно?
0
|
||||||
|
|
|||||||||||||||||
| 13.03.2019, 12:58 | |||||||||||||||||
|
2) Создаем файл конфигурации app.config. В этом файле прописываем Connection String к нашей БД (я буду конектится к стандартной БД Northwind): Кликните здесь для просмотра всего текста
3) Добавляем к проекту System.Configuration.dll (как - описано здесь). Эта длл нужна для того, что бы мы получили доступ к connectionStrings из файла конфигурации. 4) Создаем папку DAL. В ней создаем класс Repository. Содержимое класса: Кликните здесь для просмотра всего текста
Этот класс будет использоваться для получения данных из БД. Я сделал один метод - GetProducts - для получения продуктов. В метод передается код категории из которой мы хотим получить продукты. 5) На главную форму кидаем DGV и текстбокс для фильтра. В форме создаем метод Build: Кликните здесь для просмотра всего текста
Этот метод загружает DataTable из Repository (если еще не загружено), создает DataView, фильтрует его и выводит информацию в DGV. 6) Создаем обработчик события TextChanged для текстбокса фильтра. В обработчике - просто вызываем Build(); Результат: Проект целиком:
1
|
|||||||||||||||||
|
62 / 6 / 1
Регистрация: 09.09.2012
Сообщений: 137
|
|
| 13.03.2019, 16:00 [ТС] | |
|
Эхх, на работе не получается это реализовать, буду дома пробовать. Отпишусь по результатам.
Добавлено через 22 минуты Storm23, просьба ещё есть, помоги с реализацией процесса передачи информации из отсортированного уже DataView, то есть событие CellMouseDoubleClick по DataGridView, на котором прошли изменения после фильтрации Добавлено через 2 минуты На текущий момент времени у меня реализован процесс передачи информации на другую форму в TextBox, но это работает только в том случае, если не было фильтрации
0
|
|
|
|
||||||||
| 13.03.2019, 16:06 | ||||||||
1
|
||||||||
|
62 / 6 / 1
Регистрация: 09.09.2012
Сообщений: 137
|
||||||||||||||
| 13.03.2019, 21:08 [ТС] | ||||||||||||||
|
Вот пришел домой, пытаюсь разобраться с Вашими предложениями. Добавлено через 30 минут
Как следует вносить всю информацию полностью? Особенно если требуется объединение трёх таблиц с помощью JOIN. Добавлено через 31 минуту
0
|
||||||||||||||
|
|
||||
| 13.03.2019, 23:37 | ||||
|
Если нужно получить все данные, без параметров - значит нужно написать метод GetProducts() - без параметров.
0
|
||||
| 13.03.2019, 23:37 | |
|
Помогаю со студенческими работами здесь
8
Фильтрация данных в DGV в зависимости от установленных CheckBox
Фильтрация данных в datagridview Фильтрация выводимых в datagridview данных Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога
Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
|
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование
. \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json>
Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом.
# Check if. . .
|
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так:
https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347
Основана на STM32F303RBT6.
На борту пять. . .
|
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
|
|
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу,
и светлой Луне.
В мире
покоя нет
и люди
не могут жить в тишине.
А жить им немного лет.
|
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила»
«Время-Деньги»
«Деньги -Пуля»
|
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога
Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
|
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога
Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
|