Sobes.tech
Back to questions
Junior — Middle
64

Можете объяснить суть проблемы N+1 в контексте работы с базами данных?

Companies where asked
КонтурКонтур
СКАИД

Answer from AI

sobes.tech AI

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

Например, если нужно получить список пользователей и их адреса, и для каждого пользователя выполняется отдельный запрос адреса, то при 100 пользователях будет 1 запрос на пользователей + 100 запросов на адреса.

Чтобы избежать проблемы N+1, используют:

  • Жадную загрузку (eager loading) — сразу загружают связанные данные через JOIN.
  • Batch-запросы — загружают связанные данные одним запросом с фильтрацией по списку идентификаторов.

В Python с использованием ORM SQLAlchemy пример решения:

users = session.query(User).options(joinedload(User.addresses)).all()

Это позволяет получить пользователей и их адреса одним запросом, избегая N+1.