Запросы на агрегацию выполнялись на той же базе, куда активно шла запись? Никаких side-эффектов не было? Как PostgreSQL реагирует на изменение данных во время длинной агрегации?
Answer from AI
sobes.tech AI
В PostgreSQL запросы на агрегацию могут выполняться одновременно с операциями записи благодаря механизму MVCC (многоверсионного контроля конкуренции). Это означает, что каждый запрос видит консистентное состояние данных на момент начала транзакции.
Если агрегация выполняется долго, она не блокирует записи и не видит изменения, сделанные после её начала. Таким образом, side-эффектов в виде неконсистентных данных или блокировок обычно не возникает.
Однако, если агрегация требует очень свежих данных, можно использовать уровни изоляции транзакций или специальные блокировки, но это может повлиять на производительность.
Пример:
BEGIN;
SELECT COUNT(*) FROM orders WHERE created_at >= now() - interval '1 day';
COMMIT;
Этот запрос увидит состояние таблицы orders на момент начала транзакции, даже если в процессе выполнения другие транзакции добавляют новые записи.