Code-First将多个实体映射到一张数据库表

时间:2021-07-04 14:54:51

    要将多个实体映射到一个数据库表必须要满足两个条件:

  1. 两个实体必须是一对一关系;
  2. 两个实体共享一个主键。

    下面我们直接用代码来说明:  

Code-First将多个实体映射到一张数据库表Code-First将多个实体映射到一张数据库表View Code
 1 [Table("People")]
2 class Person
3 {
4 public int Id { get; set; }
5 public string Name { get; set; }
6 public bool Sex { get; set; }
7 public PersonDetail detail { get; set; }
8 }
9
10 [Table("People")]
11 class PersonDetail
12 {
13 [Key, ForeignKey("person")]
14 public int Id { get; set; }
15 public DateTime Birth { get; set; }
16 public byte[] Photo { get; set; }
17 public Person person { get; set; }
18 }
19
20 class myContext : DbContext
21 {
22 public DbSet<Person> personSet { get; set; }
23 public DbSet<PersonDetail> detailSet { get; set; }
24 protected override void OnModelCreating(DbModelBuilder modelBuilder)
25 {
26 modelBuilder.Entity<Person>().HasRequired(p => p.detail).WithRequiredPrincipal();
27 }
28 }

我们有两种方法来做映射,一种是用Data Annotation,即以上代码所示,给两个实体分别加上TableAttribute,将映射的数据表明设置为相同。这里需要注意的是,Dependent Entity的主键一定要加上ForeignKeyAttribute,否则在数据库中将会生成两个Id,一个为主键,一个为外键。我们也可以用Fluent API去做,代码如下:

Code-First将多个实体映射到一张数据库表Code-First将多个实体映射到一张数据库表View Code
1 modelBuilder.Entity<Person>().ToTable("People");
2 modelBuilder.Entity<PersonDetail>().ToTable("People");

用以上代码建立数据库:

Code-First将多个实体映射到一张数据库表