模块化系统中的EF核心

Mas*_*oud 2 c# entity-framework entity-framework-core .net-core asp.net-core

我开始用asp.net核心开发模块化系统.系统有模块加载器,模块安装程序等.每个模块都有自己动态添加的数据库模型Context

protected override void OnModelCreating(ModelBuilder modelBuilder)
{
      var typeToRegisters = new List<Type>();
      foreach (var module in GlobalConfiguration.Modules)
      {
          typeToRegisters.AddRange(module.Assembly.DefinedTypes.Select(t => t.AsType()));
      }

      RegisterEntities(modelBuilder, typeToRegisters);
      base.OnModelCreating(modelBuilder);
}

private static void RegisterEntities(ModelBuilder modelBuilder, IEnumerable<Type> typeToRegisters)
{
      var entityTypes = typeToRegisters.Where(x => x.GetTypeInfo().IsSubclassOf(typeof(IEntity<>)) && !x.GetTypeInfo().IsAbstract);
      foreach (var type in entityTypes)
      {
          modelBuilder.Entity(type);
      }
}
Run Code Online (Sandbox Code Playgroud)

但是,如果没有迁移,EF Core就无法运行.我可以为所有模块创建所有迁移文件并在start中运行它,但这是错误的.也许一个模块根本不需要安装.

有没有办法让每个模块都有自己的迁移?或以任何方式解决这个问题?

对不起,我的英语不好

谢谢

Vah*_*idN 6

但是,如果没有迁移,EF Core就无法运行.

有用!EF Core与EF 6.x不同,它没有自动迁移概念.因此,除非您要求使用context.Database.Migrate()方法应用挂起的迁移,否则它根本不会检查迁移历史记录表.因此EF Core不需要显式迁移.要测试它,只需运行您的应用程序,然后您将看到它会抱怨缺少与您实际执行的查询相关的表和字段.它根本没有抱怨失踪的迁移历史.在这种情况下,您可以单独创建数据库表,而无需使用迁移,它可以正常工作.因此,要独立工作形成迁移(这是你的问题),创建一个类似的界面

public interface  IModuleDatabaseScript
{
   string CreateSqlSchema { get;}
}
Run Code Online (Sandbox Code Playgroud)

然后你的模块应该实现这个接口并提供create database/create table/alter table/drop table等.然后你的上下文应该读取这些脚本,然后使用context.Database.ExecuteSqlCommand方法运行它们 .您应该在将模块加载到内存一次时执行此操作.在这种情况下,每个模块都可以有或没有(只返回空的CreateSqlSchema字符串)数据库创建策略,而不使用EF Core的迁移机制.

  • @Masoud使用`var sql = dbContext.GetService <IMigrationsSqlGenerator>().生成(migratonBuilder.Operations,model:null);` (2认同)