我有几个类继承了 1 个基本抽象类。它通过fluent API 映射到现有数据库(使用Table-Per-Concrete-Type,即未映射到任何表的基本抽象类)。
现在我想在我的代码中添加一些统计信息,对我来说最好的解决方案是对 3-4 个新类使用 TPH 方法。它可能继承也可能不继承与上述相同的类。
但我不知道如何指导 EF 对这 3-4 个类使用 TPH 方法。我是否需要添加带有鉴别器的正确表并且可以使用它?或者我需要通过流畅的 API 以某种方式指定它?
我有几个类继承了 1 个基本抽象类。它通过fluent API 映射到现有数据库(使用Table-Per-Concrete-Type,即未映射到任何表的基本抽象类)。
现在我想在我的代码中添加一些统计信息,对我来说最好的解决方案是对 3-4 个新类使用 TPH 方法。它可能继承也可能不继承与上述相同的类。
但我不知道如何指导 EF 对这 3-4 个类使用 TPH 方法。我是否需要添加带有鉴别器的正确表并且可以使用它?或者我需要通过流畅的 API 以某种方式指定它?
我发现。您不需要以某种方式指定要使用 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 操作。
就这些!