Проблемы с оптимизацией при использовании CTE в PostgreSQL могут возникать из-за материализации внутреннего выражения внутри конструкции WITH… AS. 1 Его вычисляют перед началом работы с остальной частью запроса, и планирование происходит без учёта остальной части. 1 Такое поведение называют барьером для оптимизации. 1
Кроме того, материализация требует ресурсов, и если выборка большая, то это может привести к проблемам. 1
До версии PostgreSQL 12 по умолчанию была материализация, но в новой версии по умолчанию её нет, и оптимизатор сразу видит весь запрос. 1
Чтобы оптимизировать запросы с CTE, можно попробовать следующие рекомендации: