在使用EntityFramework做CodeFirst开发时,经常需要将实体类映射到数据库表,但是C#实体类和数据库表中的命名遵循的是不同的规范,这就需要为每个实体类做一个到数据库表名的映射。大多情况下需要映射到的表名是有一定规则的,比如我有实体类UserEntity、RoleEntity,需要将表名分别映射为T_User、T_Role,再比如mysql的表名是全小写,可以使用以下方式实现批量映射

  public class MyDbContext : DbContext
    {
        public DbSet<UserEntity> Users{ get; set; }
        public DbSet<RoleEntity> Roles{ get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
            modelBuilder.Types().Configure(t =>
            {
           //获取类名
               var tableName = t.ClrType.Name;
         //将类名处理为指定规范表名
               tableName = "T_" + tableName.Replace("Entity","");
               t.ToTable(tableName);
            });

        }
    }

 

相关文章:

  • 2021-09-17
  • 2021-06-04
  • 2021-06-10
  • 2022-12-23
  • 2022-12-23
  • 2022-12-23
  • 2022-01-06
  • 2021-08-05
猜你喜欢
  • 2021-12-24
  • 2021-08-24
  • 2022-12-23
  • 2021-11-03
  • 2022-12-23
  • 2021-11-22
  • 2021-08-05
相关资源
相似解决方案