您的位置:首页 > 其它

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

2013-05-23 17:20 267 查看
如果我们为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; }

暂时木有解决,等待更新
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: