2

我正在尝试模拟一个场景,在该场景中我从 3rd 方库中的具体基类继承,然后使用 Entity Framework Code First 映射我自己的类。我真的希望我的类与基类具有相同的简单名称。我显然无法更改基类的类名,也无法将基类更改为抽象。正如预期的那样,我收到以下错误:

“EfInheritanceTest.Models.Order”类型和“EfInheritanceTest.Models.Base.Order”类型都具有相同的简单名称“Order”,因此不能在同一模型中使用。给定模型中的所有类型都必须具有唯一的简单名称。在 Code First fluent API 中使用“NotMappedAttribute”或调用 Ignore 以从模型中显式排除属性或类型。

据我了解,在 EF6 中,只要实际映射了其中一个类,这是可能的。但是,如果我尝试使用 fluent API 忽略基类,则会收到以下错误:

未映射类型“EfInheritanceTest.Models.Order”。使用 Ignore 方法或 NotMappedAttribute 数据注释检查该类型是否被显式排除。验证该类型是否被定义为一个类,不是原始的或泛型的,并且不是从 EntityObject 继承的。

...这似乎表明通过忽略基类,我也忽略了任何子类。完整代码如下。有什么办法可以解决这个问题并“忽略”子类?或者这是 EF 类型映射的限制?

namespace EfInheritanceTest.Models.Base
{
    public class Order
    {
        public virtual int Id { get; set; }
        public virtual string Name { get; set; }
        public virtual decimal Amount { get; set; }
    }
}

namespace EfInheritanceTest.Models
{
    public class Order : Base.Order
    {
        public virtual DateTime OrderDate { get; set; }
    }
}

namespace EfInheritanceTest.Data
{
    public class OrdersDbContext : DbContext
    {
        public OrdersDbContext() : base ("OrdersDbContext") { }

        public IDbSet<EfInheritanceTest.Models.Order> Orders { get; set; }

        protected override void OnModelCreating(DbModelBuilder modelBuilder)
        {
            base.OnModelCreating(modelBuilder);
            modelBuilder.Types<Models.Base.Order>().Configure(c => c.Ignore());
            modelBuilder.Types<Models.Order>().Configure(c => c.ToTable("order"));
            modelBuilder.Entity<Models.Order>().Map(c =>
                                                    {
                                                        c.MapInheritedProperties();
                                                        c.ToTable("order");
                                                    });

        }
    }
}
4

2 回答 2

1

无论如何,这有点晚了:我能够通过非常简单的配置解决这个问题:

modelBuilder.Ignore<MyBaseClass>();

所以 EF 根本不关心 MyBaseClass,而是与 MyInheritedClass 一起工作,因为它不是。完美的!

第二个错误与:

 modelBuilder.Types<Models.Base.Order>().Configure(c => c.Ignore());

因为您从 EF 映射中排除了这两个类(它从 Models.Base.Order 中排除了所有层次结构)。

还有一篇关于EF 继承映射的优秀帖子。

于 2017-08-18T17:47:08.777 回答
0

如果子类与父类同名,我认为这不会起作用。我确实在派生类的名称与父类不同的情况下这样做了,但是当名称相同时(我以前不知道),我看起来不可能这样做。为了测试它,我采用了我的一个项目,其中继承与 EF 一起使用,我更改了名称以适应您上面的命名方案,我得到了与您列出的相同的错误。看起来这可能是 EF 类型映射的限制。您是否可以将派生类的名称更改为与父类不同?

于 2014-07-18T19:44:04.927 回答