Что должен знать Senior .NET-разработчик про DbContext?
Что хотят услышать интервьюеры:
Senior-разработчик должен объяснить DbContext через trade-offs, диагностику, границы применения и влияние на архитектуру. Важно уметь посмотреть сгенерированный SQL и объяснить, где запрос выполняется: в БД или в памяти.
- Суть: DbContext — единица работы EF Core: хранит Change Tracker, строит запросы и сохраняет изменения.
- Где встречается: доступ к данным, миграции, запросы, транзакции и оптимизация ORM-слоя.
- Типичная ошибка: получить N+1, использовать tracking для read-only запросов или не смотреть сгенерированный SQL.
- Как отвечать: начните с короткого определения, затем приведите пример, назовите ограничение и типичную ошибку.
- Ожидаемый уровень: Senior. Глубокие trade-offs, диагностика, архитектурный контекст и влияние на систему.
Ответ:
var orders = await db.Orders.AsNoTracking().Where(o => o.UserId == userId).ToListAsync();