<b>7 мест в Django, где чаще всего прячутся медленные запросы и лишняя нагрузка</b>
Если проект начал «тормозить», первым делом смотрят не на сервер, а на ORM. В Django проблемы обычно сидят в одном из пяти слоёв: лишние JOIN'ы, N+1, неправильный select_related/prefetch_related, тяжёлые annotate и фильтры по полям без индекса.
Самая частая ошибка — тянуть объекты в шаблон или сериализатор по одному. Один список пользователей превращается в десятки запросов к профилям, ролям и последним действиям. Лечится просто: заранее собирайте связи и проверяйте итоговый SQL через django-debug-toolbar или логирование запросов.
Второй источник боли — QuerySet, который выглядит невинно, но в цикле вызывает новые обращения к базе. Сюда же попадают count(), exists(), first() и len() в неправильном месте. Если операция нужна один раз, сохраните результат в переменную, а не заставляйте ORM повторять работу 🧩
Ещё один тихий убийца — админка и служебные страницы. Там часто забывают про list_select_related, ограничение полей и пагинацию, а потом удивляются, почему простая таблица грузит базу сильнее боевого API. Проверьте эти места первыми: именно там обычно лежит быстрый выигрыш без переписывания архитектуры.
<b>Правило простое: сначала измеряйте число запросов, потом оптимизируйте код — в Django почти всегда есть быстрый фикс до того, как понадобится сложная рефакторинг-стратегия.</b>
Python Web & Scripts — Django, FastAPI, скрипты
@python_web_scripts
<b>7 мест в Django, где чаще всего прячутся медленные запросы и лишняя нагрузка</b>
Этот пост опубликован в Telegram-канале Python Web & Scripts — Django, FastAPI, скрипты. Подписаться можно по ссылке: @python_web_scripts.