Что должен знать Senior .NET-разработчик про N+1 problem?

C# / .NETГлубокие trade-offs, диагностика, архитектурный контекст и влияние на систему.Entity Framework Core and ORMТеорияcsharpdotnetentity-framework-core-and-ormef-core-performancen-1-problem

Что хотят услышать интервьюеры:

Senior-разработчик должен объяснить N+1 problem через trade-offs, диагностику, границы применения и влияние на архитектуру.

  • Суть: N+1 возникает, когда приложение выполняет дополнительный запрос для каждого элемента основной выборки.
  • Где встречается: доступ к данным, миграции, запросы, транзакции и оптимизация ORM-слоя.
  • Типичная ошибка: получить N+1, использовать tracking для read-only запросов или не смотреть сгенерированный SQL.
  • Как отвечать: начните с короткого определения, затем приведите пример, назовите ограничение и типичную ошибку.
  • Ожидаемый уровень: Senior. Глубокие trade-offs, диагностика, архитектурный контекст и влияние на систему.

Ответ:

var orders = await db.Orders.AsNoTracking().Where(o => o.UserId == userId).ToListAsync();

Источники

Похожие вопросы