Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Python: orm, performance, query

Как обычно оптимизируете медленные запросы в ORM?

Вопрос проверяет знание методов диагностики и оптимизации запросов, выполняемых через ORM.

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

Оптимизация начинается с поиска узких мест с помощью инструментов вроде django-debug-toolbar. Основные методы: использование select_related и prefetch_related для уменьшения числа запросов, добавление индексов к полям и правильное использование only() или defer() для загрузки только нужных полей. Иногда эффективнее заменить сложный запрос ORM на прямое SQL-выражение с помощью extra() или RawSQL.

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

Оптимизация запросов ORM — многоэтапный процесс, направленный на сокращение времени отклика базы данных.

Процесс оптимизации:

  1. Выявление медленных запросов:

    • Использование django-debug-toolbar для просмотра количества и времени выполнения запросов.

    • Логирование SQL-запросов в консоль разработки.

  2. Методы оптимизации:

    • Сокращение количества запросов:

      • select_related(): Выполняет SQL JOIN и загружает связанные объекты (для отношений "один к одному" и "многие к одному") за один запрос.

      • prefetch_related(): Выполняет отдельный запрос для каждой связи, но эффективно обрабатывает отношения "многие ко многим" и "один ко многим".

    • Загрузка только необходимых полей:

      • only(): Указывает, какие поля должны быть загружены немедленно. Остальные будут подгружены при обращении к ним.

      • defer(): Противоположность only(), указывает, какие поля НЕ нужно загружать сразу.

    • Использование индексов: Анализ запросов с помощью EXPLAIN и добавление индексов в модель (db_index=True) для полей, участвующих в фильтрации и сортировке.

    • Прямой SQL: Для очень сложных запросов, которые трудно выразить через ORM, используется raw() или выполняется прямое SQL-выражение.

Пример использования prefetch_related:

# Медленно: N+1 запрос
books = Book.objects.all()
for book in books:
    print(book.author.name)  # Новый запрос к БД для каждой книги

# Оптимизированно: 2 запроса
books = Book.objects.prefetch_related('author').all()
for book in books:
    print(book.author.name)  # Данные автора уже загружены

Вывод: Оптимизация ORM — это итеративный процесс анализа и применения соответствующих методов для конкретного сценария.

  • Аватар

    Python Guru

    Sergey Filichkin

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

Уровень

  • Рейтинг:

    2

  • Сложность:

    7

Навыки

  • Python

    Python

  • Django

    Django

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

#orm

#performance

#query

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

  • Аватар

    Python Guru

    Sergey Filichkin

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