Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Django: django, orm, optimization, query

Какие стандартные функции Django вы использовали для оптимизации работы с запросами и базой данных?

Проверяет знание инструментов Django ORM для оптимизации запросов к базе данных.

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

Django предоставляет select_related, prefetch_related, only, defer, annotate и aggregate для оптимизации запросов. Они помогают уменьшить количество SQL-запросов и ускорить работу приложения.

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

Django ORM предлагает несколько способов оптимизации запросов:

  • select_related – загружает связанные объекты одним JOIN-запросом (работает для ForeignKey и OneToOne).

  • prefetch_related – загружает связанные объекты отдельным запросом (подходит для ManyToMany и обратных связей).

  • only и defer – позволяют загружать только нужные поля модели, уменьшая объем данных.

  • annotate и aggregate – добавляют вычисляемые поля и агрегации без дополнительных запросов.

Пример:

# Оптимизация с select_related (ForeignKey)
books = Book.objects.select_related('author').all()  # 1 запрос вместо N+1

# Оптимизация с prefetch_related (ManyToMany)
authors = Author.objects.prefetch_related('books').all()  # 2 запроса вместо N+1

Вывод:
Используйте select_related для связей "один-ко-многим" и prefetch_related для "многие-ко-многим". only и defer помогают сократить объем данных.

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    7

Навыки

  • Django

    Django

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

#django

#orm

#optimization

#query

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

  • Аватар

    Python Guru

    Sergey Filichkin

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