• 包含和排除类型
    • 惯例
    • 数据注解
    • 流式 API

    包含和排除类型

    将类型包含到模型中意味着 EF 将获得该类型的元数据,并且将尝试从数据库读取该类型的实例或将该类型的实例写入到数据库。

    惯例

    按照惯例,在上下文中通过 DbSet 属性暴露的类型都将包含在模型中。另外,在 OnModelCreating 方法中提及的类型也会被包含在模型中。最后,通过递归扫描已包含(在模型中的)类型的导航属性所找到的任何类型都将包含在模型中。

    比如,以下代码列出的三个类型都已包含在模型中:

    • Blog 由于上下文中的 DbSet 属性暴露而被包含在模型中
    • Post 由于通过 Blog.Posts 导航属性发现而被包含在模型中
    • AuditEntry 由于在 OnModelCreating 中提及而被包含在模型中
    1. class MyContext : DbContext
    2. {
    3. public DbSet<Blog> Blogs { get; set; }
    4. protected override void OnModelCreating(ModelBuilder modelBuilder)
    5. {
    6. modelBuilder.Entity<AuditEntry>();
    7. }
    8. }
    9. public class Blog
    10. {
    11. public int BlogId { get; set; }
    12. public string Url { get; set; }
    13. public List<Post> Posts { get; set; }
    14. }
    15. public class Post
    16. {
    17. public int PostId { get; set; }
    18. public string Title { get; set; }
    19. public string Content { get; set; }
    20. public Blog Blog { get; set; }
    21. }
    22. public class AuditEntry
    23. {
    24. public int AuditEntryId { get; set; }
    25. public string Username { get; set; }
    26. public string Action { get; set; }
    27. }

    数据注解

    可以使用数据注解将某个类型从模型中排除。

    1. public class Blog
    2. {
    3. public int BlogId { get; set; }
    4. public string Url { get; set; }
    5. public BlogMetadata Metadata { get; set; }
    6. }
    7. [NotMapped]
    8. public class BlogMetadata
    9. {
    10. public DateTime LoadedFromDatabase { get; set; }
    11. }

    流式 API

    可以使用流式 API 将某个类型从模型中排除

    1. class MyContext : DbContext
    2. {
    3. public DbSet<Blog> Blogs { get; set; }
    4. protected override void OnModelCreating(ModelBuilder modelBuilder)
    5. {
    6. modelBuilder.Ignore<BlogMetadata>();
    7. }
    8. }
    9. public class Blog
    10. {
    11. public int BlogId { get; set; }
    12. public string Url { get; set; }
    13. public BlogMetadata Metadata { get; set; }
    14. }
    15. public class BlogMetadata
    16. {
    17. public DateTime LoadedFromDatabase { get; set; }
    18. }