Tutorials ASP.NET Core Tutorial
CQRS with MediatR — Complete Guide
CQRS with MediatR — Complete Guide: free step-by-step lesson with examples, common mistakes, and interview tips — part of ASP.NET Core Tutorial on Toolliyo Academy.
On this page
ASP.NET Core Tutorial (ShopNest) · Lesson 59 of 100
CQRS with MediatR
Beginner ✓ → Intermediate ✓ → Advanced → Professional
Advanced · 3 — Production skills · ~18 min read · Module 6: Advanced Features
Introduction
This is advanced material: CQRS with MediatR. It is what teams use on live products. Read the example carefully and try changing one line at a time to see what happens. CQRS with MediatR is an advanced ASP.NET Core feature for production apps — caching, background jobs, SignalR, or architecture patterns. You will not need everything on day one — read now so you recognize the tool when a project needs it.
You do not need SignalR or background jobs on day one. Read this so you recognize the tools when a project needs them.
When will you use this?
Learn these when your app needs real-time updates, files, or background jobs.
- Background services send emails and process orders without blocking HTTP responses.
- SignalR pushes live order status to the customer tracking page.
Real-world: Freshdesk-style ticket API
The Customer support team building Freshdesk-style ticket API uses CQRS with MediatR to separate read queries from write commands in large codebases. support agents never see the C# code — they just get a fast, reliable ticket queue and reply endpoints.
Production-style code
// CQRS with MediatR — apply in ShopNest when the feature needs it
builder.Services.AddHostedService<BackgroundWorker>();
What happens in production: In Freshdesk-style ticket API, getting CQRS with MediatR right means support agents trust the ticket queue and reply endpoints every day.
Lesson example (start here)
Copy this smaller example first. Once it works, compare it with the real-world code above.
// CQRS with MediatR — apply in ShopNest when the feature needs it
builder.Services.AddHostedService<BackgroundWorker>();
Line-by-line walkthrough
| Code | What it means |
|---|---|
// CQRS with MediatR — apply in ShopNest when the feature needs it | Comment — notes for humans; the compiler ignores it. |
builder.Services.AddHostedService<BackgroundWorker>(); | Registers services in dependency injection — available in controllers later. |
How it works (big picture)
- Study the example line by line.
- Each part connects to CQRS with MediatR.
- Edit one line, save, run dotnet run, and see what changes.
Do this on your computer
- Read when to use this feature vs a simpler approach.
- Try the minimal example in a branch or test project.
- Document one line on when ShopNest would need it.
- Read the real-world section and name which part of the app uses this topic.
- Run the example locally with dotnet run and confirm the same behavior.
- Change one value in the example (route, text, or connection string) and predict what will happen before you save.
Experiments — try changing this
- Change a string or route in the example and save — watch the browser or Swagger response update.
- Break the code on purpose (remove a semicolon), read the error message, then fix it.
- Use dotnet watch run while editing CQRS with MediatR — the app restarts on save.
Remember
You learned what CQRS with MediatR is and when to use it in ShopNest. Practice by changing the example yourself. Use the Next link when you can explain it in your own words.
Common questions
What is CQRS with MediatR?
CQRS with MediatR is explained in the introduction above — read it in plain language first.
How long should I spend on CQRS with MediatR?
Until you can explain it in your own words and run the example without looking at the answer. Beginners often need 30–60 minutes per new concept; setup lessons may take one afternoon.
What if I get stuck on CQRS with MediatR?
Re-read the line-by-line walkthrough, check the terminal for red errors, and compare your code character-by-character with the example. Search the exact error text — someone else had it too.
Where is CQRS with MediatR used in real jobs?
See the real-world section above — the same pattern appears in LMS, banking, e-commerce, and SaaS backends. Interviewers ask you to explain it using one concrete example.