Home / Blog / Leveling up data: Upgrade from EF6 to EF7 and blast off
Leveling up data: Upgrade from EF6 to EF7 and blast off
data:image/s3,"s3://crabby-images/65cfa/65cfa4ac69d34971ff54ce475244e725e09d84d4" alt="icon"
By EKbana on November 30, 2022
5m readUpgrade from Entity Framework 6 to Entity Framework 7 for improved performance, support for new data stores, and a simplified, modular architecture. Plan the upgrade, check compatibility, update dependencies, and test the application.
.NET Framework 4.8 and EF 6
We have a straightforward web API developed with the traditional.NET Framework 4.8, and Entity Framework 6 serves as our ORM. EF6 is not the same as EF Core 6.
We measure the response time for inserting, updating, and deleting one entity as well as a thousand entities.
We utilized Benchmark.NET, which is a standard method of executing effective tests in.Net.
data:image/s3,"s3://crabby-images/43bd3/43bd31e4e8904a829ce188251e54c11125ed0b54" alt=""
data:image/s3,"s3://crabby-images/2d150/2d1501625f76bd3d391525d26e89f45db26444ef" alt=""
We moved the Web API to.NET 7, however we are still mostly utilizing EF6 as our ORM. Both traditional.NET 4.8 and the most recent.NET 7 are compatible with EF 6. None of our business logic needed to be updated.
We re-ran the same benchmarks. Let us now see the graphs.
data:image/s3,"s3://crabby-images/412f7/412f7fd721292ee71332acc3587f6a934304965e" alt=""
Without modifying any of our code, we can enhance performance by about 20% by simply moving from.NET 4.8 to.NET 7.
data:image/s3,"s3://crabby-images/a8969/a89693f9c154bafe4d3b1602f1fed7b8e4f59013" alt=""
For 1000 entities, the CRUD operation hasn't really improved much. This is the result of 1000 records requiring roundtrips to the database. This is how EF 6 operates.
Then, we reran our benchmarks after upgrading our API from EF 6 to EF 6 Core (the LTS version that was released last year), not EF 7 Core (which is the most recent version we will be doing this in a while). Let's examine the outcomes.
data:image/s3,"s3://crabby-images/5f828/5f828fa28a7f11e90266976a4db7de9ed4c031d1" alt=""
Once more, moving to has resulted in a performance improvement of about 10% by switching to EF Core 6.
The business logic itself has not changed at all; just minimal code changes, such as initializing constructors and changing code references, were required.
data:image/s3,"s3://crabby-images/60852/60852686e1a2ff69b1cd33ca7b411d4adaab9110" alt=""
We see a massive improvement in CRUD operation of 1000 entities. It's like 10 times better performance.
EF 6 will do round trips to database for every records
EF 6 CORE has batching optimization built in which will result in reduced round trips. It takes the set of these records as a batch and sends them to the server.
We now upgrade our ORM to EF CORE 7 and then re-run the benchmarks.
data:image/s3,"s3://crabby-images/31a39/31a39025116368d1b2b3226705bf83ffa18c9a94" alt=""
One thousand entities CRUD operations have been improved. It performs about ten times better.
For each record, EF 6 will make round visits to the database.
Due to batching optimization incorporated into EF 6 CORE, round trips will be decreased. It sends the entire collection of these records to the server in one batch.
data:image/s3,"s3://crabby-images/31e07/31e07b8d28b9023dbec7fb504fc5f529faad8572" alt=""
You can see bulk insert operation is also 20 percent faster with .NET 7 Core.
data:image/s3,"s3://crabby-images/b3542/b3542b75c31de89f90782f9fbd67d2fd56edb0fa" alt=""
Some new features of EF CORE 7 :
ExecuteDeleteAsync();
ExecuteUpdateAsync();
JSON viewmodel support for entities and query etc
Using these new features we can write efficient query codes and avoid unnecessary round trips to the database.
data:image/s3,"s3://crabby-images/5a93c/5a93c66b85b5da18b322e06861c00c9532d8572e" alt=""
Upgrading your projects to the latest version of .NET and EF will drastically improve your application performance.