E.F Core – Existing Database
Hi everyone! Today, I want to talk about an interesting feature of E.F Core. Many times, we need to begin a project with an existing database and this isn’t the old school with Database first (I miss it 🙁 ) however we have tools with we can attack the problem 😉
Let’s code!
First step: Startup – New project
I need to create a project, in my case a Migration Console Project (Net Core).
data:image/s3,"s3://crabby-images/4b240/4b24055b82b73da126588b4eadad8b5d95bb0fb0" alt=""
The second step – Installing packages!
We need to interact with the database, in our case, we’ll interact with a SQL Server DB. For this reason, we need to install the NuGet package: Microsoft.EntityFrameworkCore.SqlServer.
data:image/s3,"s3://crabby-images/6475b/6475bb017c1e7b274d2cdc5f01c2bd2ca3f39c68" alt=""
Then, we need to install: Microsoft.entityframeworkcore.Design package NuGet too. This package has the logic to use Migrations and Reverse Engineering.
data:image/s3,"s3://crabby-images/23d37/23d37717fa14a2f10bc98c14c183ab50ab246538" alt=""
Thirst step: Mapping tables!
Now, we work with the Package Nuget Console. If we go to E.F Documentation, we can see the following example:
PM> Scaffold-DbContext "Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models
This command will apply reverse engineering over every table in the database and it will create all models.
In this case, the entities will be in a Models folder (namespace projectName.Models)
We can specify which tables we want to migrate with the following command: -Tables. For example:
PM> Scaffold-DbContext "Server=(localdb)\mssqllocaldb;Database=Blogging;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models --Tables Table1,Table2,Table3
In our case, we will interact with a SQL DATABASE with login and we want to get all Tables. In addition, we want that every new class are in Entities namespace.
PM> Scaffold-DbContext "Server = DATABASE_SERVER_NAME; Database = BD_NAME; persist security info=True;user id=USER;password=PASSWORD;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Entities
data:image/s3,"s3://crabby-images/ff09e/ff09e75e8ee763b8b50700491c408f47b1230b71" alt=""
Result:
data:image/s3,"s3://crabby-images/cffac/cffacf121b48106b772abd0487b5c1f033028d13" alt=""
We can see the new entities in our project and the DB Context!
Fourth step: Say Hello to the DB!
We use a using block to instantiate the CONTEXT and then we retrieve all categories from the DB.
data:image/s3,"s3://crabby-images/55f92/55f92d7aaf2a49ab67d5ce915988d6dd93356124" alt=""
data:image/s3,"s3://crabby-images/6ae3b/6ae3bc208e50b6c83025efca98c706a8004a6408" alt=""
That’s all!
Big hug!
1 thought on “E.F Core – Existing Database”
Leave a Reply
You must be logged in to post a comment.
There is noticeably a bundle to realize about this. I suppose you made some good points in features also.