Что такое N+1 problem и зачем это нужно?
Что хотят услышать интервьюеры:
N+1 problem — N+1 возникает, когда приложение выполняет дополнительный запрос для каждого элемента основной выборки.
- Суть: N+1 возникает, когда приложение выполняет дополнительный запрос для каждого элемента основной выборки.
- Где встречается: доступ к данным, миграции, запросы, транзакции и оптимизация ORM-слоя.
- Типичная ошибка: получить N+1, использовать tracking для read-only запросов или не смотреть сгенерированный SQL.
- Как отвечать: начните с короткого определения, затем приведите пример, назовите ограничение и типичную ошибку.
- Ожидаемый уровень: Middle. Практическое применение в проекте, ограничения и типовые ошибки.
Ответ:
var orders = await db.Orders.AsNoTracking().Where(o => o.UserId == userId).ToListAsync();