0

我有几个类继承了 1 个基本抽象类。它通过fluent API 映射到现有数据库(使用Table-Per-Concrete-Type,即未映射到任何表的基本抽象类)。

现在我想在我的代码中添加一些统计信息,对我来说最好的解决方案是对 3-4 个新类使用 TPH 方法。它可能继承也可能不继承与上述相同的类。

但我不知道如何指导 EF 对这 3-4 个类使用 TPH 方法。我是否需要添加带有鉴别器的正确表并且可以使用它?或者我需要通过流畅的 API 以某种方式指定它?

4

1 回答 1

1

我发现。您不需要以某种方式指定要使用 TPH 的 EF。足以做到以下几点:

创建类层次结构

class Base { ... }
class Derived1 : Base { ... }
class Derived2 : Base { ... }
.......
class DerivedN : Base { ... }

创建称为基本类型的表(否则不要忘记使用模型构建器对其进行映射),其中包含公共列(内容Base),并且每个派生类型中的每个公共属性都有一列。添加“鉴别器”列nvarchar(128),但我建议使用 varchar,除非您使用 unicode 类名称)。

在 DbContext 的继任者中仅添加一个 DbSet:DbSet<Base> Data { get; set; }并将其用于 CRUD 操作。

就这些!

于 2013-01-23T19:15:07.613 回答