Is there a way to do what this code did in EF Core RC 2?
protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Conventions.Remove<PluralizingTableNameConvention>(); }
What is pluralize and singularize in the Entity Framework dialog box? “Pluralize” and “Singularize” give meaningful naming conventions to objects. In simple words it says do you want to represent your objects with the below naming convention: One Customer record means “Customer” (singular).
There is no convention for this as of EF RC2 build. This is from EF Core team:
In past pre-release of EF Core, the table name for an entity was the same as the entity class name. In RC2 we now use the name of the DbSet property. If no DbSet property is defined for the given entity type, then the entity class name is used.
Now if you want to revert back to the RC1 naming conventions for tables, you have 3 ways to go with:
1. Choosing Singular Names for DbSet Properties:
One way is to singularize your DbSet property names (which I don't like). Say for example you have a Book entity and you want to map to a Book table:
public DbSet<Book> Book { get; set; }
2. Using ToTable() Fluent API:
You can of course always use fluent API to override any convention in place and dictate the table name to whatever you want:
modelBuilder.Entity<Book>().ToTable("Book");
3. Writing a Custom Convention:
Just because EF Core RC2 does not have a convention for this, it doesn't mean we can't write our own. To do so, first we need to create an extension method on ModelBuilder
object:
using Microsoft.EntityFrameworkCore.Metadata.Internal; public static class ModelBuilderExtensions { public static void RemovePluralizingTableNameConvention(this ModelBuilder modelBuilder) { foreach (IMutableEntityType entity in modelBuilder.Model.GetEntityTypes()) { entity.Relational().TableName = entity.DisplayName(); } } }
And then we simply call it from the OnModelCreating method on our DbContext object:
protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.RemovePluralizingTableNameConvention(); }
On Closing:
I don't like plural table names and I like the last option better than the others and went with that. That said, it's my personal opinion and other developers might find any of these 3 ways more favorable than the others and choose to go with that :)
For EF Core 3.0 and above, use this to set the TableName
property (because entity.Relational()
no longer exist):
public static class ModelBuilderExtensions { public static void RemovePluralizingTableNameConvention(this ModelBuilder modelBuilder) { foreach (IMutableEntityType entity in modelBuilder.Model.GetEntityTypes()) { entity.SetTableName(entity.DisplayName()); } } }
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With