Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Entity Framework Core 5 (EF Core 5) and beyond - table name pluralization

Prior to EF Core 5, I've been able to use this code (pasted below) successfully from this original Stack Overflow post Entity Framework Core RC2 table name pluralization

This allowed me to specify SQL tables which persist my entities to use singular names. This doesn't appear to work after upgrading beyond EF Core 3. Most of the posts in Stack Overflow around this topic are dated many years prior. There is one post in the article linked above dated 1/29/2021 which makes mention of the "-NoPluralize" switch for Scaffold-DbContext, except I'm not scaffolding from an existing DB, I'm using the code-first methodology. This is also mentioned in Microsoft's https://learn.microsoft.com/en-us/ef/core/what-is-new/ef-core-5.0/breaking-changes#pluralizer

I've also tried upgrading to EF Core 6.0.3 to see if this may have been addressed by chance in this release. Unfortunately no luck.

Stepping across the code for entity.SetTableName, both entity.DisplayName() and entity.ShortName() methods return the proper singular name strings, so I know SetTableName() is receiving the proper string.

Investigating the SetTableName method in the RelationalEntityTypeExtension class in the EF Core source out on GitHub doesn't reveal anything interesting or abnormal, that is if I'm looking at the correct class.

There's bound to be a solution for this, I couldn't possibly be the only one :-) Any suggested articles or techniques to try? The only thing left I can think of to try is to get breakpoints on some of the EF sources with some debug symbols and see what's going on beyond just my code. Any input or guidance would be tremendously helpful!

In my context class, pluralizing invoked by:

protected override void OnModelCreating(ModelBuilder modelBuilder){
  modelBuilder.RemovePluralizingTableNameConvention();
}

In pluralizing method implemented in an extension class:

public static class ModelBuilderExtensions{
 public static void RemovePluralizingTableNameConvention(this ModelBuilder modelBuilder){
  foreach (var entity in modelBuilder.Model.GetEntityTypes()){
    entity.SetTableName(entity.DisplayName());
   }
  }
}
like image 972
BSmith Avatar asked Oct 14 '25 16:10

BSmith


2 Answers

EF Core 7+ supports it natively:

protected override void ConfigureConventions(ModelConfigurationBuilder configurationBuilder)
{
    configurationBuilder.Conventions.Remove(typeof(TableNameFromDbSetConvention));
}

Using this takes table name from entity type name (unless [Table] attribute has been applied to it).

like image 120
Saul Avatar answered Oct 17 '25 06:10

Saul


Ok, well I guess we'll just chalk this one up to general weirdness. @Ivan Stoev, thanks for your patience. I targeted .NET Core 5, EF Core 5.0.15, dropped all tables, rebuilt, ensured .bin was empty, added a new migration, applied the migration, and all the tables were named singular. So, i repeated that exact same process, except this time put everything back to .NET 6, EF 6.0.3. All the tables rebuilt with singular names, which is the desired result. I'm baffled but happy now. Must have been classic PEBKAC :-D

like image 26
BSmith Avatar answered Oct 17 '25 05:10

BSmith



Donate For Us

If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!