169 похожих чатов

Коллеги, добрый день В поисках способов оптимизации одного тяжелого запроса, пришел

к идее использования indexed view как механизма предварительной агрегации данных.
Конкретнее - есть таблица с движениями в + и в - и я в моем запросе получаю остаток по этой таблице в разрезе одних суток и других группировок, т.е. каждый раз рассчитываю это.
Хочу сделать indexed view с уже рассчитанными агрегациями, но смущает то, что данные в таблице таки изменяются (порядок цифр - под сотню тысяч изменений в сутки) и насколько наличие view скажется на производительности. Или может быть есть более адекватное решение предрасчета агрегации?

4 ответов

10 просмотров

Обычно просто делают табличку и там обновляют значение. Главное Лок на строчку агрегации не забывать вешать.

Осторожно с таблицей агрегации, можно блокировки словить.

Если юзать хинты на Лок строки вначале транзакции, то не выйдет

Да делай обычную таблицу.. Точнее, набор. Периоды, входящие остатки, движение средств в периоде, их сумма жалеет текущие остатки. Период закрывается - всё, остатки менять нельзя. Формируются входящие остатки на след. Период

Похожие вопросы

Обсуждают сегодня

Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
38
Проблема с Windows scripting control Множество объектов получают iDispatch обертки и отдаются в скрипты. При этом скрипты могут эти обертки держать живыми очень долго, наприм...
Arioch The
16
Я тут пытаюсь переработать архитектуру подсистемы памяти ядра во что-то осмысленное. Есть pmm, который создает набор range’ей(пока что только для ядра, потом для юзерспейса), ...
Evg Resh
9
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
20
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
коллеги, а есть простой способ определить, что программу из под Delphi запускают?
Михаил
10
40 тысяч в час / 3600 = 11,11 в секунду... Вам точно нужна очередь? (я просто не знаю "контекста") Такое количество запросов любое приложение замечательно "прожует" и не попер...
Igor Mitin
5
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
Карта сайта