• 继承(关系数据库)
    • 惯例
    • 数据注解
    • 流式 API

    继承(关系数据库)

    注意

    当前章节中涉及的配置一般适用于关系数据库。这里展示的扩展方法在你安装了关系数据库提供程序之后就能获得(由Microsoft.EntityFrmeworkCore.Relational 程序包共享)。

    EF 模型中的继承被用来控制实体类型继承在数据库中的表现方式。

    惯例

    按照惯例,使用每个层次结构一张表(table-per-hierarchy,TPH)的模式来进行映射。TPH 使用单一的表来存储类层次结构中所有类型的数据,然后使用识别列来辨别每一行所对应的实体类型。

    EF 将只会在两个或多个继承类型被显式包含到模型中时建立继承(详见 继承)。

    以下样例展示了一个简单类层次结构的场景,其中的数据使用 TPH 模式被存储到关系数据库中。识别列 标识了每一行所存储的 Blog 类型。

    1. class MyContext : DbContext
    2. {
    3. public DbSet<Blog> Blogs { get; set; }
    4. public DbSet<RssBlog> RssBlogs { get; set; }
    5. }
    6. public class Blog
    7. {
    8. public int BlogId { get; set; }
    9. public string Url { get; set; }
    10. }
    11. public class RssBlog : Blog
    12. {
    13. public string RssUrl { get; set; }
    14. }

    类层次结构TPH数据

    数据注解

    不能使用数据注解来配置继承。

    流式 API

    可以使用流式 API 来配置识别列的类型和名称,以及用于辨别类层次结构中的类型的值。

    1. class MyContext : DbContext
    2. {
    3. public DbSet<Blog> Blogs { get; set; }
    4. protected override void OnModelCreating(ModelBuilder modelBuilder)
    5. {
    6. modelBuilder.Entity<Blog>()
    7. .HasDiscriminator<string>("blog_type")
    8. .HasValue<Blog>("blog_base")
    9. .HasValue<RssBlog>("blog_rss");
    10. }
    11. }
    12. public class Blog
    13. {
    14. public int BlogId { get; set; }
    15. public string Url { get; set; }
    16. }
    17. public class RssBlog : Blog
    18. {
    19. public string RssUrl { get; set; }
    20. }