EF Core如何处理继承关系 TPH/TPT/TPC继承策略配置

admin 百科 12
EF Core 提供 TPH、TPT、TPC 三种继承映射策略:TPH 单表靠 Discriminator 区分类型,查询快但易出 NULL;TPT 每类一表、规范化强但需 JOIN;TPC 各类独立成表、无外键但无法统一查询所有子类。

EF Core如何处理继承关系 TPH/TPT/TPC继承策略配置-第1张图片-佛山资讯网

EF Core 通过三种主流策略处理类继承与数据库表之间的映射:TPH(单表)、TPT(每类型一表)、TPC(每具体类一表)。选哪种不取决于“哪个更高级”,而要看你对查询性能、数据规范性和维护成本的实际权衡。

TPH:单表继承,最常用也最容易踩坑

所有派生类数据存进一张表,靠 Discriminator 字段区分类型。这是 EF Core 默认策略,配置最轻量。

  • 基类和所有子类的属性都变成该表的列,未使用的字段值为 NULL
  • 查询快——不用 JOIN,一条 SELECT 就能拿到任意类型实例
  • 必须显式配置鉴别器字段名和值,否则可能报 “Cannot insert NULL into Discriminator”
  • 示例配置:
    modelBuilder.Entity()
      .HasDiscriminator("AnimalType")
      .HasValue("Cat")
      .HasValue("Dog");

TPT:按类型分表,结构清晰但查询变慢

基类一个表,每个派生类单独一张表,子表通过外键引用基表主键。适合强调数据规范化、空值敏感或已有成熟分表设计的场景。

标签: app

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~