RESTful CRUD Api using Entity Framework Core's In-Memory (O/RM) Database - C# ASP.Net Core Web Api
data:image/s3,"s3://crabby-images/aad8f/aad8f684129dc601261ce1c68fa4185b30be0d82" alt="RESTful CRUD Api using Entity Framework Core's In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Use Case
I recently needed to implement a CRUD layer in a RESTful Api, however the decision regarding which database context to use to store our data hadn’t quite happened. Given this, I decided to build an abstract implementation which would allow us to “plug-and-play” our chosen database framework into the Api at a later date.
Rather than going down the route of spinning up a cloud database to test out the abstraction, I decided to use an in-memory database context…
Enter “Microsoft’s Entity Framework Core”…
“Entity Framework (EF) Core is a lightweight, extensible, open source and cross-platform version of the popular Entity Framework data access technology. EF Core serves as an object-relational mapper (O/RM), enabling .NET developers to work with a database using .NET objects, and eliminating the need for most of the data-access code they usually need to write.”
data:image/s3,"s3://crabby-images/e390c/e390c035b4d18c3fb0dc0a94ae97270385823c9c" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
If you’ve ever had the luxury of using the Entity Framework you’re already well aware of how capable it is and how awesome O/RM is, not to mention how clean the implementation is to work with. Fortunately they now support .Net Core, so let’s give it a whirl and build a RESTful CRUD Api using the Entity Framework In-Memory Database!
Let’s Code…
Today’s example is based on storing a series of blog posts via a RESTful CRUD Api. First, create a fresh ASP.Net MVC Core project and then pull in a copy of the relevant package from Nuget.
data:image/s3,"s3://crabby-images/8d793/8d7932c846addbfd5565d378c855c9bf1f7f2ade" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Our abstraction will work as follows: Controller > Service > Repository > Database Context
Let’s start by defining a data model to use -
data:image/s3,"s3://crabby-images/4ad30/4ad307693bb1a9afd7f47ec773e0b193d62fb41f" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Next we need to code our database context layer by defining our database table for our blog post entities, and setting our primary key.
data:image/s3,"s3://crabby-images/9c168/9c1687a76f77314381f4495d745a8422e855a318" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Now to inject our database context into our repository via ServiceScope.
data:image/s3,"s3://crabby-images/87a5e/87a5e428b95001d8a68b62148ba77305ad27399c" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
We can now add a basic “create” method to our repository.
data:image/s3,"s3://crabby-images/0e0cc/0e0cc80f870ba97e77d91dd3e82d794c766cee1e" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Next we inject our repository into our service layer, along with a “create” method which binds to the equivalent repository method.
data:image/s3,"s3://crabby-images/04aff/04afff092ef5447587bf5552ca653db725bc0281" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Now we can inject our service into our controller.
data:image/s3,"s3://crabby-images/f8acd/f8acd29c9cbdb80b79ed464ffa397c6fa2dd253f" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
…Followed by our controller action for our “create” process flow, along with some simple validation via FluentValidation.
data:image/s3,"s3://crabby-images/d175e/d175eeb40c9fec9db50fc8637089975ed21c6c62" alt="Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api"
Entity Framework Core’s In-Memory (O/RM) Database - C# ASP.Net Core Web Api
Finally we can configure our dependency injection within our Startup.cs file.
data:image/s3,"s3://crabby-images/fbc17/fbc17d4e3c32bdbe8547ea74e6db01abd578578a" alt=""
Testing Our Implementation
Let’s fire up Postman and submit data to our Api endpoints…
data:image/s3,"s3://crabby-images/8f9bc/8f9bc6af013bf0b641687a201789f02e6f04b984" alt=""
…Result!
Enjoy!