Аватар для salaev
2 / 2 / 0
Регистрация: 27.03.2018
Сообщений: 114

Заполнение TStringGrid из запроса

04.06.2021, 07:34. Показов 580. Ответов 4

Студворк — интернет-сервис помощи студентам
Подскажите пожалуйста, как быстрее (правильнее) заполнить TStringGrid из запроса? Сейчас заполняю так:
Delphi
1
2
3
4
5
6
7
8
  While not fAssist.Query_tabl.EOF do
  begin
        SG.RowCount:= SG.RowCount + 1;
        SG.Cells[1, SG.RowCount-1]:= fAssist.Query_tabl.FieldByName('Mark').AsString;
        SG.Cells[2, SG.RowCount-1]:= fAssist.Query_tabl.FieldByName('FIO').AsString;
        SG.Cells[3, SG.RowCount-1]:= fAssist.Query_tabl.FieldByName('Status').AsString;
        fAssist.Query_tabl.Next;
  end;
Но на 20 столбцов и 5000 строк уходит некоторое время, что не очень радует

P.S.: Жалею, что раньше не прислушался к совету Volvo и не перешел на этот компонент вместо DBGrid. Некоторые вопросы, такие как сортировка и закрепление строк/столбцов ушли сами собой...
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
04.06.2021, 07:34
Ответы с готовыми решениями:

Заполнение элементов TStringGrid
Как разрешить простому юзеру самостоятельно заполнять с клавиатуры элементы TStringGrid'а?

Заполнение TstringGrid заглавными буквами
нужно заполнить TsringGrid вручную (т.е.самостоятельно внести в каждую ячейку строковые значения) и при этом чтобы автоматически все...

Заполнение TStringGrid из текстового файла
Есть файл db.txt в котором формат текста: Данные1 : Данные 2 Данные1 : Данные 2 Данные1 : Данные 2 Данные1 : Данные 2 есть...

4
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,410
Записей в блоге: 3
04.06.2021, 07:42
Цитата Сообщение от salaev Посмотреть сообщение
Но на 20 столбцов и 5000 строк уходит некоторое время
А зачем вообще тянуть весь набор данных в приложение? Сделали запрос с требуемыми условиями и показали полученные 5-10-15 записей...
0
 Аватар для salaev
2 / 2 / 0
Регистрация: 27.03.2018
Сообщений: 114
04.06.2021, 08:39  [ТС]
Рабочая таблица, в которой я делаю поиск, устанавливаю фильтра и т.д. может иметь много строк для просмотра.
Возможно как то подгружать динамически при прокручивании списка. Ведь DBGrid на сколько я понимаю тоже подтягивает данные по мере прокрутки.
Только как организовать такое пока не могу сообразить

Добавлено через 1 минуту
визуально же не вся таблица перед глазами, а только ее небольшая часть
0
Модератор
 Аватар для D1973
9924 / 6460 / 2457
Регистрация: 21.01.2014
Сообщений: 27,410
Записей в блоге: 3
04.06.2021, 08:54
Цитата Сообщение от salaev Посмотреть сообщение
Рабочая таблица, в которой я делаю поиск, устанавливаю фильтра и т.д. может иметь много строк для просмотра.
Да и на здоровье, пусть она хоть 100500 мильёнов записей имеет... Для чего их все в приложение тащить? Пора понять, что БД - это не таблица Excel, нет абсолютно никакой необходимости визуализировать весь набор данных. И работать с ней надо посредством SQL-запросов, а не фильтров по полному набору. Ведь куда как проще, быстрее и практичнее получить из БД только те данные, которые нужны, который я сам запрашиваю, чем тянуть в приложение весь НД, отображать в визуальном компоненте (что само по себе - тормоз еще тот) чтобы потом его фильтровать...
0
 Аватар для salaev
2 / 2 / 0
Регистрация: 27.03.2018
Сообщений: 114
04.06.2021, 09:14  [ТС]
Да я мозгом то это уже понимаю. Реализацию затрудняюсь исполнить. Поиск и фильтры все делаю в запросе.
Как мне визуализировать только те данные, которые я хочу увидеть при прокрутке???
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
04.06.2021, 09:14
Помогаю со студенческими работами здесь

Заполнение нескольких таблиц TStringGrid одними и теми же значениями
Доброго всем времени суток. Подскажите пожалуйста, как реализовать вот такой функционал. На одной форме лежит несколько StringGrid-ов....

Заполнение ТЧ одного документа ТЧ другого, заполнение тч из запроса
&НаСервере Процедура ЗаполнитьНаСервере() Запрос = Новый Запрос; Запрос.Текст = "ВЫБРАТЬ ...

Динамической заполнение запроса
Доброго времени суток!!! Народ у меня есть jQuery код,он создает input поля и в зависимости от кол-ва полей дает им имена т.е. 1,2,3 и т.д....

Заполнение списка из запроса
Имеется таблица в Oracle (5 полей, col1....col5). col1 - varchar col2 - varchar col3 - Date col4 - Date col5 - number Имеется...

Заполнение TreeView из запроса
Здравствуйте, у меня вот какая проблема, мне надо заполнить дерево TreeView из запроса Сам запрос select Главная_тема, Наименование,...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Опции темы

Новые блоги и статьи
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это дополнительная запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая. . .
[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-среде способ разработки чаще всего предполагает монорепозиторий в котором находятся все исходники. При создании нового решения, мы просто добавляем нужные проекты и имеем. . .
Модульный подход на примере F#
DevAlt 06.03.2026
В блоге дяди Боба наткнулся на такое определение: В этой книге («Подход, основанный на вариантах использования») Ивар утверждает, что архитектура программного обеспечения — это структуры,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru