|
Ищущий знания
11 / 8 / 4
Регистрация: 31.05.2015
Сообщений: 209
|
|
Оптимизация DataGridView09.06.2018, 14:44. Показов 2318. Ответов 9
Метки нет (Все метки)
Доброго времени суток и всех с наступающим праздником!
Пишу программу на winForm. Программа коннектится к БД access и нужно из неё(БД) вывести в приложении таблицу для просмотра. У меня получилось вывести, все отображается правильно, но когда даже таблица пустая в форме и я изменяю размер окна, то начинает все дёргаться. (Компьютер мощный у меня). И если строк больше чем на весь экран (т.е. при сароллинге), все начинается долго листаться, как будто fps жутко маленький. Сама таблица обновляется строго по нажатию одной кнопки, поэтому при сароллинге новых данных не поступает. Находил инфу, что можно поменять параметр DoubleBuffer - он немного помог, но не достаточно. Что посоветуете? P.S. саму БД в проект не добавлял, но вроде и пробовал добавить , но ситуация не улучшилась
0
|
|
| 09.06.2018, 14:44 | |
|
Ответы с готовыми решениями:
9
|
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
|
| 11.06.2018, 09:13 | |
|
Не выводить 100500 строк в грид. Работать с макс 1000 строк - более пользователю увидеть будет сложно. Также использовать байндинг, а строки хранить в отдельном объекте, не привязывая напрямую к гриду.
0
|
|
|
Ищущий знания
11 / 8 / 4
Регистрация: 31.05.2015
Сообщений: 209
|
||
| 11.06.2018, 09:28 [ТС] | ||
|
Выводить я собирался не более 400, но повторюсь, даже с 8 строками и 8 столбцами (даже если они пустые,) то лагает перескакивание
0
|
||
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
|
| 11.06.2018, 10:31 | |
|
код какой для грида? - Каким образом устанавливаете связь между таблицей с гридом?
0
|
|
|
Ищущий знания
11 / 8 / 4
Регистрация: 31.05.2015
Сообщений: 209
|
||||||||||||
| 12.06.2018, 22:25 [ТС] | ||||||||||||
|
Это вывод в таблицу
Это коннектится к базе
Повторяюсь, лаги даже с пустым гридом. Вот видео
0
|
||||||||||||
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
|
| 13.06.2018, 09:15 | |
|
Открой для себя DataTable - забудь о том, что написал, всё, что с 11 строки (окромя закрытия ридера).
Никогда не делай присвоение строк в грид - у него есть замечательное свойство DataSource. По поводу ридера - если так уж сильно хочется пользоваться именно ридером, то DataTable имеет 2 замечательных метода - BeginLoadData() и EndLoadData() - дабы отключить все уведомления, констрейнты и т.д. А вот то чудовище, что написано сейчас - срочно нужно удалить и забыть о нем.
1
|
|
|
Ищущий знания
11 / 8 / 4
Регистрация: 31.05.2015
Сообщений: 209
|
|
| 13.06.2018, 09:18 [ТС] | |
|
0
|
|
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
||
| 13.06.2018, 10:00 | ||
|
0
|
||
|
Ищущий знания
11 / 8 / 4
Регистрация: 31.05.2015
Сообщений: 209
|
||
| 13.06.2018, 10:03 [ТС] | ||
|
0
|
||
|
360 / 287 / 76
Регистрация: 21.06.2016
Сообщений: 1,115
|
|||||||||||
| 13.06.2018, 10:33 | |||||||||||
|
Смотря как заливать данные в таблицу.
Можно заливать с помощью асинхронной операции, используя таску и метод adapter.Fill(DataTable dt). По поводу отдельных столбцов - тут вариантов несколько: 1. Используя команду в БД - указывая только нужные столбцы из таблиц/представлений 2. Используя клиент - и наполняя новую таблицу из уже существующей, приводя таблицу к DataView
типа
1
|
|||||||||||
| 13.06.2018, 10:33 | |
|
Помогаю со студенческими работами здесь
10
Во втором DataGridView отобразить данные, используя значения выбранной строчки первого DataGridView Вывод информации в DataGridView в зависимости от выбора в другом DataGridView Нужно, чтобы при выборе элемента в одном DataGridView отображались связанные данные в другом DataGridView DataGridView и Access, составить запрос для dataGridView
Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
Новые блоги и статьи
|
|||
|
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git
main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели
8ATzM_2aurI
|
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2.
Задача: запретить редактирование документа, если он открыт у другого пользователя.
/ / . . .
|
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои.
А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
|
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20%
kYBz3eJf3jQ
|
|
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
|
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
|
Использование значений реквизитов справочника в документе, с определенными условиями и правами
Maks 07.04.2026
1. Контроль срока действия договора
Алгоритм из решения ниже реализован на примере нетипового документа "ЗаявкаНаРаботу", разработанного в конфигурации КА2.
Задача: уведомлять пользователя, если. . .
|
Доступность команды формы по условию
Maks 07.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2.
Задача: сделать доступной кнопку (команда формы "ЗавершитьСписание") при. . .
|