© 2026 Hedgehog Software, LLC

TwitterGitHubDiscord
More
CommunitiesDocsAboutTermsPrivacy
Search
Star
Setup for Free
C#C
C#•2y ago•
17 replies
Joschi

✅ EFCore fetching all data in nearly all tables after a single insert

So today I encountered the weirdest error, for which I cannot create a minimal reproducible project.
But maybe any of you has any clue on how this is even possible or even why it occours.

The project is a .NET7 WebAPI with EFCore pointing towards an SQLServer 2019.
We had an object using an auto incrementing
int
int
ID.

class MyDbObject
{
  public int Id {get;}
 //...
}
class MyDbObject
{
  public int Id {get;}
 //...
}


We changed that to use a
StronglyTypedId
StronglyTypedId


[StronglyTypedId]
readonly partial struct ObjectId
{
  // This and a lot of plumbing and parsong code is source generated, like a EFCore Value converter and so on.
  public int Value {get;}
} 
[StronglyTypedId]
readonly partial struct ObjectId
{
  // This and a lot of plumbing and parsong code is source generated, like a EFCore Value converter and so on.
  public int Value {get;}
} 


We used this strong ID implementation multiple times and it works without any problems.

Now we had a implicit conversion on the ID for convenience.
[StronglyTypedId]
readonly partial struct ObjectId
{
  public static implicit operator ObjectId(MyDbObject obj) => obj.Id;
} 
[StronglyTypedId]
readonly partial struct ObjectId
{
  public static implicit operator ObjectId(MyDbObject obj) => obj.Id;
} 


Now EFCore started to literally fetch the entire database into memory after doing the single and correct
INSERT
INSERT

Always selecting all properties of the entire table and sending it back to the client.
_dbContext.Add(myObjectInstance);
await _dbContext.SaveChangesAsync();
_dbContext.Add(myObjectInstance);
await _dbContext.SaveChangesAsync();

Removing the implicit conversion completely resolved this.

This did not happen if it was isolated in a unit test and ran against a test database instance.
Because of that it most likely is some configuration on the DBContext or the project.

I'm at a complete loss, so maybe one of you has any inkling what the cause of this could be.
C# banner
C#Join
We are a programming server aimed at coders discussing everything related to C# (CSharp) and .NET.
61,871Members
Resources

Similar Threads

Was this page helpful?
Recent Announcements

Similar Threads

✅ Add tables in a project with EFCore
C#CC# / help
3y ago
❔ EFCore finding a single entry
C#CC# / help
3y ago
✅ EFCore Tables with inharitance
C#CC# / help
3mo ago
Data fetching in components?
C#CC# / help
16mo ago