Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Django: orm, optimization, query, n+1

Как оптимизировать запрос для отчета по наличию книг в магазинах (N+1 problem)?

Проверяет умение решать проблему N+1 — частую ошибку, когда приложение делает избыточное количество запросов к базе данных.

Короткий ответ

Проблема N+1 возникает, когда для каждого объекта в списке (N) делается отдельный запрос (+1 начальный). В Django её решают с помощью select_related (для ForeignKey) или prefetch_related (для ManyToMany). Это объединяет запросы, уменьшая их количество с N+1 до 1-2.

Длинный ответ

Проблема N+1 — типичная антипаттерн при работе с ORM:

  1. Сначала получаем список объектов (1 запрос).

  2. Для каждого объекта запрашиваем связанные данные (+N запросов).

Пример проблемы:

# Получаем все магазины (1 запрос)
shops = Shop.objects.all()

for shop in shops:
    	# Для каждого магазина запрашиваем книги (N запросов)
    	books = shop.books.all()  
    	print(f"{shop.name}: {books.count()} книг")

Итог: 1 (магазины) + N (книги на магазин) запросов.

Решение в Django:

  • prefetch_related() для ManyToMany-связей (книги в магазинах):

    shops = Shop.objects.prefetch_related('books').all()
    # Теперь всего 2 запроса: 
    # 1. Получить магазины.
    # 2. Получить ВСЕ книги для этих магазинов.
  • Как работает:

    1. Django делает первый запрос для получения магазинов.

    2. Второй запрос получает все связанные книги за раз.

    3. ORM автоматически связывает книги с магазинами в памяти.

Когда использовать:

  • Для связей «многие ко многим» (ManyToManyField).

  • Для обратных связей ForeignKey (например, book_set).

Вывод:
prefetch_related уменьшает нагрузку на БД и ускоряет работу приложения.

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    2

  • Сложность:

    6

Навыки

  • Django

    Django

Ключевые слова

#orm

#optimization

#query

#n+1

Подпишись на Python Developer в телеграм

  • Аватар

    Python Guru

    Sergey Filichkin

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.