EF中为表添加一些设置后如何自动关联

如果我们为Student表添加了一些字段配置放在  StudentConfiguration.cs

那么在   public class StudentContext : DbContext  应该进行如下配置

 protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
   modelBuilder.Configurations.Add(new StudentConfiguration());
   base.OnModelCreating(modelBuilder);
        }

但是如果我们为每张表都添加一些配置属性,那么如果表多了这将是一件繁琐的工作,所以我们可以自动循环添加

protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            //modelBuilder.Configurations.Add(new StudentConfiguration());
            var typesToRegister = Assembly.GetExecutingAssembly().GetTypes()
            .Where(type => !String.IsNullOrEmpty(type.Namespace))
            .Where(type => type.BaseType != null && type.BaseType.IsGenericType && type.BaseType.GetGenericTypeDefinition() == typeof(EntityTypeConfiguration<>));
            foreach (var type in typesToRegister)
            {
                dynamic configurationInstance = Activator.CreateInstance(type);
                modelBuilder.Configurations.Add(configurationInstance);
            }
            base.OnModelCreating(modelBuilder);
        }

上面的问题解决了,还有这个呢,每张表也要添加一次

public DbSet<Student> Students { get; set; }

暂时木有解决,等待更新

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值