Форум по Delphi программированию

Delphi Sources



Вернуться   Форум по Delphi программированию > Все о Delphi > Базы данных
Ник
Пароль
Регистрация <<         Правила форума         >> FAQ Пользователи Календарь Поиск Сообщения за сегодня Все разделы прочитаны

Ответ
 
Опции темы Поиск в этой теме Опции просмотра
  #1  
Старый 22.03.2018, 17:57
Bangerok Bangerok вне форума
Прохожий
 
Регистрация: 22.03.2018
Сообщения: 2
Версия Delphi: Delphi 7
Репутация: 10
По умолчанию Ускорение обработки ~ 1000000 записей

Задача: ускорить обработку и отображение данных.

Исходные данные:

1. Есть база данных FireBird 2.5, в которой больше 1000000 записей.
2. Для получения и отображения данных используются компоненты TpFIBDataSet [FIBPlus] и TcxExtLookupComboBox [DevExpress].
Сейчас работает так: есть 6 TpFIBDataSet, которые связаны между собой, и 6 TcxExtLookupComboBox, в которых отображаются данные из тех шести датасетов.
3. Каждый раз при выборе записи в одном из датасетов, происходит перевыборка во всех подчиненных. Я хочу этого избежать, то есть уменьшить количество обращений к базе данных.

Мое предположительное решение: убрать связь master-detail, и использовать свойство Filtered.

Вопрос: Насколько вырастет или упадет производительность отображения данных? И есть ли еще какие решения?
Ответить с цитированием
  #2  
Старый 22.03.2018, 20:58
Аватар для Guaho
Guaho Guaho вне форума
Начинающий
 
Регистрация: 27.08.2017
Сообщения: 173
Версия Delphi: Delphi7
Репутация: 10
По умолчанию

Думаю, фильтрация не поможет, по сути она ничем не отличается от master-detail. В последнем случае фильтрация делается автоматически, а в первом - придётся прописывать руками, но принципиальное убыстрение процесса тут вряд ли возможно.
Возможный вариант - отображать (читать из БД) подчинённые записи только по требованию пользователя.
Ответить с цитированием
  #3  
Старый 22.03.2018, 23:31
Аватар для Alegun
Alegun Alegun вне форума
LMD-DML
 
Регистрация: 12.07.2009
Адрес: Богородское
Сообщения: 3,025
Версия Delphi: D7E
Репутация: 1834
По умолчанию

Цитата:
Сообщение от Guaho
...Возможный вариант - отображать (читать из БД) подчинённые записи только по требованию пользователя.
Да наверное, это есть единственный такой вариант
Ответить с цитированием
  #4  
Старый 23.03.2018, 09:02
Bangerok Bangerok вне форума
Прохожий
 
Регистрация: 22.03.2018
Сообщения: 2
Версия Delphi: Delphi 7
Репутация: 10
Вопрос

Цитата:
Сообщение от Guaho
Думаю, фильтрация не поможет, по сути она ничем не отличается от master-detail. В последнем случае фильтрация делается автоматически, а в первом - придётся прописывать руками, но принципиальное убыстрение процесса тут вряд ли возможно.
Возможный вариант - отображать (читать из БД) подчинённые записи только по требованию пользователя.

Почему не отличается от master-detail? Я правильно понимаю, что если выполнить Filtered, то не происходит обращения к базе, а просто перебирается выборка в датасете и все записи, которые не удовлетворяют условию в Filtered отсекаются?
Ответить с цитированием
Ответ


Delphi Sources

Опции темы Поиск в этой теме
Поиск в этой теме:

Расширенный поиск
Опции просмотра

Ваши права в разделе
Вы не можете создавать темы
Вы не можете отвечать на сообщения
Вы не можете прикреплять файлы
Вы не можете редактировать сообщения

BB-коды Вкл.
Смайлы Вкл.
[IMG] код Вкл.
HTML код Выкл.
Быстрый переход


Часовой пояс GMT +3, время: 00:25.


 

Сайт

Форум

FAQ

RSS лента

Прочее

 

Copyright © Форум "Delphi Sources" by BrokenByte Software, 2004-2023

ВКонтакте   Facebook   Twitter