Кэширование результата vs постоянный пересчёт того же самого? Сервер отдаёт клиентам какие-то данные. К примеру, отчёт о статистике магазина за сутки. Он содержит строки с суммами покупок, включая все налоги и прочее и последняя строка это сумма по всем категориям (требуется суммировать много всего и множество строк). Суммарный налог за все товары, суммарная сумма покупок и т.п. То есть при каждом запросе на сервер нужно давать эти данные всем кто попросит. Как лучше это организовать - каждый раз пересчитывать сумму по новой для каждого запроса, или хранить поле "сумма" в БД и при добавлении новой покупки увеличивать его?
P.S. Если постоянно считать то же самое, теоретически, процесс будет работать впустую. Зачем бесконечно раз пересчитывать одно и тоже, когда можно просто хранить результат и обновлять его по мере прихода новых строк в таблицу?

21 Авг 2019 в 06:21
254 +1
0
Ответы
1

Оптимальнее будет использовать кэширование результата, то есть хранить уже посчитанное значение "сумма" в БД и обновлять его при добавлении новой покупки. Постоянный пересчёт того же самого может потреблять лишние ресурсы сервера и замедлить работу системы, тогда как кэширование позволит быстро отдавать клиентам уже готовые данные. Кроме того, при кэшировании можно установить механизмы обновления кэша, например, через определенный интервал времени или при определенных событиях, чтобы результат всегда был актуальным.

20 Апр 2024 в 13:19
Не можешь разобраться в этой теме?
Обратись за помощью к экспертам
Название заказа не должно быть пустым
Введите email
Бесплатные доработки
Гарантированные бесплатные доработки
Быстрое выполнение
Быстрое выполнение от 2 часов
Проверка работы
Проверка работы на плагиат
Интересные статьи из справочника
Поможем написать учебную работу
Название заказа не должно быть пустым
Введите email
Доверьте свою работу экспертам
Разместите заказ
Наша система отправит ваш заказ на оценку 95 839 авторам
Первые отклики появятся уже в течение 10 минут
Прямой эфир