有没有办法在EF Core RC 2中执行此代码?
protected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.Conventions.Remove<PluralizingTableNameConvention>(); }
EF RC2版本没有这个惯例.这是来自EF Core团队:
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.
现在,如果您想恢复到表的RC1命名约定,您有3种方法可以使用:
1.为DbSet属性选择奇异名称:
一种方法是单独化你的DbSet属性名称(我不喜欢).比如说你有一个Book实体,并且想要映射到Book表:
public DbSet<Book> Book { get; set; }
2.使用ToTable()Fluent API:
当然,您总是可以使用流畅的API来覆盖任何适当的约定,并根据您的需要指定表名:
modelBuilder.Entity<Book>().ToTable("Book");
3.编写自定义公约:
仅仅因为EF Core RC2没有这方面的约定,这并不意味着我们不能自己编写.为此,首先我们需要在ModelBuilder对象上创建一个扩展方法:
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();
}
}
}
然后我们简单地从DbContext对象上的OnModelCreating方法调用它:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
modelBuilder.RemovePluralizingTableNameConvention();
}
关闭时:
我不喜欢复数表格名称,我比其他选项更喜欢最后一个选项,并且顺其自然.也就是说,这是我的个人意见,其他开发者可能会发现这三种方式中的任何一种都比其他方式更优惠,并选择与之相配:)