ASP.NET Core Complete Tutorial (ShopNest)
Lesson 16 of 75 21% of course

EF Core LINQ Queries — Beginner to Advanced

1 · 5 min · 5/24/2026

Learn EF Core LINQ Queries — Beginner to Advanced in our free ASP.NET Core Complete Tutorial (ShopNest) series. Step-by-step explanations, examples, and interview tips on Toolliyo Academy.

Sign in to track progress and bookmarks.

EF Core LINQ Queries — Beginner to Advanced — ShopNest
Article 16 of 75 · Module 2: Entity Framework Core · ShopNest E-Commerce Order System
Target keyword: ef core linq queries · Read time: ~32 min · .NET: 8 / 9 · Project: ShopNest E-Commerce Order System

Introduction

LINQ (Language Integrated Query) is how you talk to ShopNest's database in C# — filter orders, sum revenue, paginate product lists, and join customers to orders without writing raw SQL for every screen.

This lesson covers query syntax vs method syntax, filtering, projection, sorting, grouping, joins, aggregates, pagination, raw SQL escape hatches, and performance patterns like AsNoTracking().

After this article you will

  • Write LINQ method syntax fluently for ShopNest order queries
  • Use Where, Select, Include, GroupBy, and aggregates
  • Paginate with Skip/Take and project to DTOs
  • Run FromSqlRaw when LINQ is not enough
  • Avoid lazy-loading N+1 traps on order lists

Prerequisites

Concept deep-dive

Query vs method syntax

// Method syntax (preferred in teams)
var pending = await _db.Orders
    .Where(o => o.Status == OrderStatus.Pending)
    .OrderByDescending(o => o.CreatedAt)
    .Select(o => new OrderListDto { Id = o.Id, Total = o.Total })
    .ToListAsync();

// Query syntax (same IL, personal preference)
var q = from o in _db.Orders
        where o.Status == OrderStatus.Pending
        orderby o.CreatedAt descending
        select new OrderListDto { Id = o.Id, Total = o.Total };

Filtering & aggregates

Where, Any, All, Contains for filters. Aggregates: CountAsync, SumAsync, AverageAsync, Min/Max — always async in production.

Eager loading & joins

var order = await _db.Orders
    .Include(o => o.Customer)
    .Include(o => o.Lines).ThenInclude(l => l.Product)
    .FirstOrDefaultAsync(o => o.Id == id);

// Pagination
var page = await _db.Orders
    .AsNoTracking()
    .OrderBy(o => o.Id)
    .Skip((pageNum - 1) * pageSize)
    .Take(pageSize)
    .ToListAsync();

AsNoTracking() for read-only grids — no change tracking overhead. Lazy loading can cause N+1: one query per order line — prefer explicit Include.

Raw SQL

var topCustomers = await _db.Customers
    .FromSqlRaw("SELECT * FROM Customers WHERE TotalSpend > {0}", 50000)
    .AsNoTracking()
    .ToListAsync();

Hands-on — ShopNest E-Commerce Order System

  1. Add Order, OrderLine, Customer entities to ShopNest DbContext.
  2. OrdersController.Index: paginated list with status filter query string.
  3. Dashboard action: Sum of today's revenue, count of pending orders.
  4. Enable EF SQL logging in Development to inspect generated SQL.
public async Task<OrderDashboardVm> GetDashboardAsync()
{
    var today = DateTime.UtcNow.Date;
    return new OrderDashboardVm
    {
        PendingCount = await _db.Orders.CountAsync(o => o.Status == OrderStatus.Pending),
        TodayRevenue = await _db.Orders
            .Where(o => o.CreatedAt >= today && o.Status == OrderStatus.Paid)
            .SumAsync(o => o.Total)
    };
}

Common errors & best practices

  • Client-side evaluation: calling .ToList() before Where pulls entire table into memory.
  • SELECT *: project to DTOs — never return full entities to API consumers.
  • Lazy loading in loops: enable SQL log and watch query count explode.

Interview questions

Q1: LINQ query vs method syntax?
A: Same expression tree; method syntax is more common in C# codebases.

Q2: Include vs lazy loading?
A: Include eager-loads in one query; lazy loading fires extra queries per navigation access — dangerous in loops.

Q3: When AsNoTracking?
A: Read-only lists, reports, API GET — any time you won't call SaveChanges on results.

Q4: Skip/Take pagination problem?
A: Offset pagination slows on large tables — keyset pagination (WHERE Id > lastId) scales better (Article 20).

Summary

  • LINQ translates to SQL — keep filters server-side
  • Include/ThenInclude prevent N+1 on order details
  • AsNoTracking and DTO projection improve read performance
  • FromSqlRaw for reports LINQ cannot express cleanly

Previous: EF Core CRUD Operations
Next: EF Core Relationships

FAQ

Does LINQ run in the database?

EF Core translates IQueryable to SQL until ToListAsync/FirstOrDefaultAsync executes.

Can I mix LINQ and raw SQL?

Yes — FromSqlRaw on DbSet, then LINQ Where on top (must start from composable SQL).

Test your knowledge

Quizzes linked to this course—pass to earn certificates.

Browse all quizzes
ASP.NET Core Complete Tutorial (ShopNest)

On this page

Introduction After this article you will Prerequisites Concept deep-dive Query vs method syntax Filtering &amp; aggregates Eager loading &amp; joins Raw SQL Hands-on — ShopNest E-Commerce Order System Common errors &amp; best practices Interview questions Summary FAQ Does LINQ run in the database? Can I mix LINQ and raw SQL?
Module 1: Foundations
What is ASP.NET Core? Complete Guide Setting Up ASP.NET Core Development Environment ASP.NET Core Project Structure Explained MVC Architecture in ASP.NET Core — Complete Guide Controllers and Actions in ASP.NET Core Routing in ASP.NET Core — Conventional and Attribute Routing Views and Razor Syntax in ASP.NET Core Layouts, Partial Views and View Components Models and ViewModels in ASP.NET Core Forms, Model Binding and Validation in ASP.NET Core Tag Helpers in ASP.NET Core — Complete Guide Static Files, Bundling and Minification in ASP.NET Core
Module 2: Entity Framework Core
Entity Framework Core — Introduction and Setup EF Core Code First — Models, Migrations, Database EF Core CRUD Operations — Create, Read, Update, Delete EF Core LINQ Queries — Beginner to Advanced EF Core Relationships — One-to-One, One-to-Many, Many-to-Many EF Core Fluent API — Advanced Configuration EF Core Repository Pattern and Unit of Work EF Core Performance Optimization Database First Approach with EF Core (Scaffold) EF Core with SQL Server — Advanced Features
Module 3: Dependency Injection & Middleware
Dependency Injection in ASP.NET Core — Complete Guide Middleware in ASP.NET Core — Complete Guide Configuration in ASP.NET Core — appsettings, Environment Variables, Secrets Filters in ASP.NET Core — Action, Authorization, Exception, Resource, Result Logging in ASP.NET Core — ILogger, Serilog, NLog Error Handling and Exception Management in ASP.NET Core
Module 4: Authentication & Security
ASP.NET Core Identity — Complete Setup Guide Authentication in ASP.NET Core — Cookie and JWT Authorization in ASP.NET Core — Roles, Policies, Claims JWT Authentication with Refresh Tokens — Complete Implementation OAuth2 and External Login (Google, Facebook, Microsoft) Data Protection and Encryption in ASP.NET Core HTTPS, SSL Certificates and Security Best Practices
Module 5: Web API
Building REST APIs with ASP.NET Core — Complete Guide API Versioning in ASP.NET Core Swagger / OpenAPI Documentation in ASP.NET Core Input Validation in Web APIs — FluentValidation and Data Annotations Pagination, Filtering and Sorting in ASP.NET Core APIs HTTP Client and Consuming External APIs in ASP.NET Core Minimal APIs in ASP.NET Core .NET 8 SignalR — Real-Time Web Applications
Module 6: Advanced Architecture
Clean Architecture in ASP.NET Core CQRS Pattern with MediatR in ASP.NET Core Repository Pattern — Deep Dive with Generic Repository Background Services and Hosted Services in ASP.NET Core Caching in ASP.NET Core — In-Memory, Distributed, Redis Health Checks in ASP.NET Core AutoMapper in ASP.NET Core Microservices with ASP.NET Core — Introduction Message Queues with RabbitMQ / Azure Service Bus in ASP.NET Core gRPC with ASP.NET Core
Module 7: Testing
Unit Testing ASP.NET Core with xUnit and Moq Integration Testing in ASP.NET Core Testing EF Core — In-Memory vs SQLite Performance Testing and Load Testing ASP.NET Core APIs Test-Driven Development (TDD) in ASP.NET Core
Module 8: Deployment & DevOps
Deploying ASP.NET Core to IIS on Windows Server Docker and Containerization for ASP.NET Core Deploying ASP.NET Core to Azure App Service CI/CD with GitHub Actions for ASP.NET Core Azure SQL Database with ASP.NET Core Environment Configuration and Secrets Management
Module 9: Real-World Projects
Build a Complete Blog Website with ASP.NET Core MVC Build an E-Commerce Product Catalog API (ASP.NET Core Web API) Build a Student Management System (Complete CRUD App) Build a Job Portal (Full Stack ASP.NET Core) Build a REST API with Clean Architecture — Complete Guide Build a Real-Time Chat App with SignalR and ASP.NET Core
Module 10: Advanced Topics
Blazor WebAssembly and Blazor Server — Complete Guide gRPC, GraphQL and Alternative API Styles in ASP.NET Core Rate Limiting and API Throttling in ASP.NET Core .NET 8 Output Caching in ASP.NET Core .NET 8 ASP.NET Core .NET 9 New Features — Complete Guide