zoukankan      html  css  js  c++  java
  • EntityFramework中实体类到表名的批量映射

    在使用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);
                });
    
            }
        }
  • 相关阅读:
    浅读《构建之法》
    def 和 lamdba的区别
    Numpy和Pandas的区别
    Django:每点击一次就增加行可输入的表格
    F函数和Q函数的作用
    super()的用法
    liunx操作系统
    celery(超详细)
    celery
    FastDFS环境搭建
  • 原文地址:https://www.cnblogs.com/oyang168/p/11171893.html
Copyright © 2011-2022 走看看