Entity Framework (EF) Core is a lightweight, extensible, open source and cross-platform version of Entity Framework data access technology. It’s rewritten version of Entity Framework Object-Relation-Mapper for .NET Core. It’s under .NET Foundation , hosted on GitHub, mainly developed by Microsoft, but totally open source. On short, you can use it everywhere: commercial apps, open source, you can propose changes and contribute to the development.
Permissions and licensing are under very very open and friendly .NET Core philosophy!!!!
EF enables two paradigms: Code-First and Database-First paradigm.
In this blog post I will show latter option. I will show how to scaffold or extract classes from existing relation database and us it in C# project.
Code-Fist approach means that you defined domain objects with all relations in your application and then database is generated based on your classes and relation between them. This option is generally better approach for greenfield projects – when you do your app from start.
Database-First approach means that you already have database and you need to generate domain object for your app. This approach is particular useful for developers who are more database-centric, or if database already exists (e.g. legacy systems) and we just need app to talk to this database.
As said, In this blog post I will show how to generate domain object from relation database and then later on use it in your app. For this, I will use only dotnet tool and console – no Visual Studio or some other fancy tools.
Scaffolding database structure into C# classes
Basic prerequisite is to install .NET Core 3.1 SDK. When you install this SDK you will get dotnet CLI tool. You can find more info about the tool here: https://docs.microsoft.com/en-us/dotnet/core/tools/.
For more Visual Studio type of developers: you can do everything with this. You can build, create project, add references to projects and a lot more. Furthermore, console based approach is very useful when you want to automatize some things. Therefore, I will use only console to do the job.
When I install this SDK I have dotnet tool available on my system.
You an find SDKs for different targets and platforms here: https://dotnet.microsoft.com/download/dotnet-core/3.1
data:image/s3,"s3://crabby-images/3577b/3577b0c5867bf3ff41b529c94f0c3136ccdc6477" alt="dotnet tool version command"
I can check which tools are registered in dot net core tool repository, by using dotnet list command:
data:image/s3,"s3://crabby-images/12f9f/12f9fdfc337e6467ff043f935f0af27318b48af8" alt="dotnet tool list tool command"
First, I need to install EF tool and register it globally.
data:image/s3,"s3://crabby-images/6e564/6e564c16d49669201c88d171fafa7b525cba531c" alt="dotnet tool install command"
Now, that I have EF tool available in my arsenal…
data:image/s3,"s3://crabby-images/f7cfc/f7cfcbd6df58e2c7dc9ea03af66e3bd70c15a5a7" alt="dotnet tool list command"
I can start my scaffolding process.
First, I create empty folder.
data:image/s3,"s3://crabby-images/852f8/852f8891186446fdee93fe2e4c50864ca0cb6606" alt="create new folder for test"
Inside I create empty class library class to put my scaffolded classes in.
data:image/s3,"s3://crabby-images/8e367/8e3673d442dc54c2e59b95bb5c3e06cd50b310d9" alt="dotnet tool create empty class library project"
Output: csproj with dummy Class1 class.
data:image/s3,"s3://crabby-images/42499/42499fcb75c5b18dc19947581a23b088a7263491" alt="new csproj check"
EF needs two NuGet references in order to work:
- Microsoft.EntityFrameworkCore.Design
- Microsoft.EntityFrameworkCore.SqlServer
So I put them in in my project. Of course via my dotnet tool!
data:image/s3,"s3://crabby-images/ac907/ac9073359dd168673b025bf0caa2f95ee7e4c202" alt="dotnet tool adding package reference command"
data:image/s3,"s3://crabby-images/df67f/df67f4b9f34578370a744ba8c49cd92466659669" alt="dotnet tool adding package reference command"
Now, that everything is on place, the magic begins. I will scaffold my classes from existing SQL Server database. Let’s try
data:image/s3,"s3://crabby-images/285d9/285d97caffb99e461865a03851b57fdcdd1eb634" alt="dotnet tool ef scaffold command"
Models folder is created with all database mapped C# classes.
data:image/s3,"s3://crabby-images/e427b/e427b5ad96634101a400c0fa6b57b7c63436262d" alt="directory structure listing"
Let’s check our database structure quickly
data:image/s3,"s3://crabby-images/094d5/094d59b3acc57db3fd0124b526262f165e134488" alt="ssms project"
and compare with scaffolded C# classes:
data:image/s3,"s3://crabby-images/d7fb4/d7fb4004385ba4a25c78b00632167f4217f4d450" alt="visual studio project"
Everything is on place, classes in my C# project and DBContext class generated and ready to use in my application.
Command summary
Let’s quickly list commands I used for EF Database-First approach to generate my C# data classes.
1 2 3 4 5 6 7 8 9 10 11 12 13 |
dotnet -- version dotnet tool list --global dotnet tool install dotnet-ef --global dotnet new classlib -f netcoreapp3.1 dotnet add <project-name>.csproj package Microsoft.EntityFrameworkCore.Design dotnet add <project-name>.csproj package Microsoft.EntityFrameworkCore.SqlServer dotnet ef dbcontext scaffold "Server=.;Database=BikeStores2;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -o Models --project <project-name>.csproj |
Conclusion
If you are doing greenfield project you will most probably generate database from your code. In this case, you will used Code-First paradigm. But this approach is not necessary the best option.
Some developers (especially old-school ones 🙂 ) are more database-centic, so they are very comfortable with SQL/relational databases. In this case, you can use database first approach to use EF ORM mapping.
In this post I presented latter option. I presented how you can do EF Object-Relational mapping from existing database, generate business classes, DbContext and use it in your app. I did this by using dotnet tool and console.
Until the next time, happy coding.