我有一个构建在实体框架核心2.2.x上的现有应用程序。它使用modelBuilder.ApplyConfiguration()动态地将实体与数据模型相关联。对于所有当前实体,甚至我的新AuditLog实体,对于应用程序的其余部分来说,这都是可行的。
但是,当我将Audit.NET的实体框架核心提供程序配置为登录到AuditLog时,数据提供程序无法写入数据库:
没有找到实体类型'AuditLog‘。确保已将实体类型添加到模型中。
我在互联网上搜索了该错误的解决方案,并发现将这一行添加到我的代码中将导致Audit.NET找到我的AuditLog:
modelBuilder.Entity<AuditLog>().ToTable("AuditLog", "Audit");
我的代码:
protected override void OnModelCreating(ModelBuilder modelBuilder)
{
Type[] maps = EntityFrameworkReflectionMapping.Get(EntityTypeConfiguration(), BoundAssemblies);
foreach (object instance in maps.Select(Activator.CreateInstance))
modelBuilder.ApplyConfiguration((dynamic)instance);
modelBuilder.Entity<AuditLog>().ToTable("AuditLog", "Audit");
base.OnModelCreating(modelBuilder);
}为什么我需要显式地添加该实体,而系统的其他部分则以-is方式工作?
此外,Audit.NET正在通过未显式添加的实体检测更改。因此,问题似乎在于Audit.NET的实体框架数据提供程序,或者我是如何使用它的。
我希望数据提供者会尊重modelBuilder.ApplyConfiguration()方法来关联实体。
发布于 2019-07-25 02:51:05
有许多原因可能导致异常,但看起来EF无法检测到AuditLog的实体表关系。
查找错误的连接字符串,可能您的AuditLog是在与其他实体不同的程序集中定义的。
还尝试将AuditLog实体类作为DbContext上的属性添加到db集中,例如:
public class MyContext : AuditDbContext
{
//...
public DbSet<ModelName> ModelName { get; set; }
}https://stackoverflow.com/questions/57190729
复制相似问题