一.概述
EF实体关系定义了两个实体互相关联起来(主体实体和依赖实体的关系,对应数据库中主表和子表关系)。 在关系型数据库中,这种表示是通过外键约束来体现。本篇主要讲一对多的关系。先了解下描述关系的术语。
(1) 依赖实体: 这是包含外键属性的实体(子表)。有时称为 child 。
(2) 主体实体: 这是包含主/备用键属性的实体(主表)。 有时称为 parent。
(3) 外键:依赖实体(子表)中的属性,用于存储主表的主键属性的值。
(4) 主键: 唯一标识的主体实体(主表)的属性。 这可能是 primary key 或备用键。
(5) 导航属性: 包含对相关实体引用,在的主体和或依赖实体上定义的属性。
集合导航属性: 一个导航属性,对多个相关实体的引用。
引用导航属性: 一个导航属性,对单个相关实体的引用。
下面示例代码来说明Blog和Post之间的一对多关系。其中 Post 是依赖实体;Blog 是主体实体;Post.BlogId 是外键;Blog.BlogId 是主键;Post.Blog引用导航属性;Blog.Posts集合导航属性。
public class Blog
{
public int BlogId { get; set; }
public string Url { get; set; }
public List Posts { get; set; }
}
public class Post
{
public int PostId { get; set; }
public string Title { get; set; }
public string Content { get; set; }
public int BlogId { get; set; }
public Blog Blog { get; set; }
}
二.约定
按照约定,当在实体类型上发现导航属性时,将创建关系。如果属性所指向的类型不能被当前数据库提供程序映射为标量类型,则将其视为导航属性。下面用三个示例来说明通过约定创建的主从实体关系。
2.1 完全定义的关系
关系最常见的模式是在关系的两端定义导航属性,并在依赖实体类中定义外键属性。
(1)如果两个类型之间找到一对导航属性,则它们将被配置为同一关系的反转导航属性。
(2)如果依赖实体包含名为的属性, ,或然后它将配置为外键。
下面代码示例是完全定义的关系的实体,通过约定来创建主从实体关系。
public class Blog
{
public int BlogId { get; set; }
public string Url { get; set; }
//反转导航属性
public List Posts { get; set; }
}
public class Post
{
public int PostId { get; set; }
public string Title { get; set; }