EntityFramework中实体类到表名的批量映射

匿名 (未验证) 提交于 2019-12-02 23:47:01

在使用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);             });          }     }

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!