Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

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

Как prefetch_related и select_related помогают избежать проблемы N+1?

Проверяет понимание проблемы N+1 запроса и способов её решения в Django.

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

select_related загружает связанные данные одним JOIN-запросом, а prefetch_related делает отдельный запрос и кэширует результаты. Оба метода предотвращают множественные запросы при обращении к связанным объектам.

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

Проблема N+1:
Когда вы получаете список объектов и затем обращаетесь к их связанным данным, Django делает отдельный запрос для каждого объекта. Например:

books = Book.objects.all()  # 1 запрос
for book in books:
    print(book.author.name)  # N запросов (по одному на каждую книгу)

Решение:

  1. select_related – загружает связанные объекты через JOIN:

    books = Book.objects.select_related('author').all()  # 1 запрос

    Подходит для ForeignKey и OneToOne.

  2. prefetch_related – делает отдельный запрос и кэширует результаты:

    authors = Author.objects.prefetch_related('books').all()  # 2 запроса

    Подходит для ManyToMany и обратных связей.

Вывод:
Используйте select_related для "простых" связей и prefetch_related для "сложных".

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    6

Навыки

  • Django

    Django

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

#django

#orm

#n+1

#optimization

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

  • Аватар

    Python Guru

    Sergey Filichkin

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