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

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

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

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 PersonDetail12     {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 : DbContext21     {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去做,代码如下:

View Code

1 modelBuilder.Entity<Person>().ToTable("People");2 modelBuilder.Entity<PersonDetail>().ToTable("People");

用以上代码建立数据库:

转载于:https://www.cnblogs.com/Allen-Li/archive/2012/04/05/2433309.html

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

  1. jpa 实体映射视图_JPA教程:实体映射-第2部分

    jpa 实体映射视图 在上一篇文章中,我展示了一种持久保存实体的简单方法. 我解释了JPA用于确定实体默认表的默认方法. 假设我们要覆盖此默认名称. 我们之所以喜欢这样做,是因为数据模型是以前设计和修 ...

  2. JPA教程:实体映射-第2部分

    在上一篇文章中,我展示了一种持久保存实体的简单方法. 我解释了JPA用于确定实体默认表的默认方法. 假设我们要覆盖此默认名称. 我们之所以喜欢这样做,是因为数据模型是以前设计和修复的,并且表名与我们的 ...

  3. java实体类生成mysql表_springboot+mybatis通过实体类自动生成数据库表的方法

    前言 本章介绍使用mybatis结合mysql数据库自动根据实体类生成相关的数据库表. 首先引入相关的pom包我这里使用的是springboot2.1.8.RELEASE的版本 org.mybatis ...

  4. 推荐一个 Java 实体映射工具 MapStruct

    声明: 1.DO(业务实体对象),DTO(数据传输对象). 2.我的代码中用到了 Lombok ,不了解的可以自行了解一下,了解的忽略这条就好. 在一个成熟的工程中,尤其是现在的分布式系统中,应用与应 ...

  5. 开源实体映射框架EmitMapper介绍

    综述 EmitMapper是一个开源实体映射框架,地址:http://emitmapper.codeplex.com/. EmitMapper映射效率比较高,接近硬编码.EmitMapper采用emi ...

  6. Java实体映射工具MapStruct

    声明: 1.DO(业务实体对象),DTO(数据传输对象). 2.我的代码中用到了 Lombok ,不了解的可以自行了解一下,了解的忽略这条就好. 1 2 3 在一个成熟的工程中,尤其是现在的分布式系统 ...

  7. jpa 实体映射视图_JPA教程:映射实体–第1部分

    jpa 实体映射视图 在本文中,我将讨论JPA中的实体映射过程. 至于我的示例,我将使用与 我以前的一篇文章中使用的模式相同的模式 . 在前两篇文章中,我解释了如何在Java SE环境中设置JPA. ...

  8. JPA教程:JPA概述、JPA实体生命周期、JPA实体映射关系、JPA查询语言

    JPA定义了Java ORM及实体操作API的标准.本文摘录了JPA的一些关键信息以备查阅. 如果有hibernate的基础,通过本文也可以快速掌握JPA的基本概念及使用. 1 JPA概述 JPA(J ...

  9. java EF6,EF Core 2.0和EF6(Entity Framework 6)中配置实体映射关系

    1.EF6中通过EntityTypeConfiguration配置实体映射关系代码 public class AccountMap : EntityTypeConfiguration { public ...

最新文章

  1. Bootstrap4 更新笔记
  2. python数据库操作sqlite_Python操作mysql和sqlite
  3. docker oom 排查过程
  4. 在DrawingVisual上绘制圆形的进度条,类似于IOS系统风格。
  5. mysql 进阶方向_mysql数据库入门、进阶和提升(续二)
  6. 百度SEO快克工具包 1.5.0 官方版
  7. php sql 字段不能为空值,关于php:Sudden SQL问题-一般错误:1364字段没有默认值
  8. eSIM物联网卡的优点有哪些
  9. 看看我能帮上大家的什么忙? 文平
  10. delphi.about.com 上的教材链接
  11. asp上传服务器后台图片显示,asp.net上传图片到服务器方法详解
  12. spring aop聊点不一样的东西
  13. (二)html 复杂表格
  14. 医学统计学-为什么是个医学生就都要学R语言?
  15. VS2013创建Windows服务 || VS2015+Windows服务简易教程
  16. 巨佬Jake Wharton谈Android对Java 8的支持
  17. 【冬瓜哥雄文】高端存储系统江湖风云录!
  18. django oscar_赢得奥斯卡奖之后会发生什么
  19. Linux 打印机移植说明
  20. 实验吧WEBWP(一)

热门文章

  1. 用python的pandas打开csv文件_使用CSV模块和Pandas在Python中读取和写入CSV文件
  2. jquery获取加载的html内容,jquery 获取ajax加载的html中部分内容
  3. javascript手册安卓版_JavaScript 完全手册(2018版)
  4. Java经纬度坐标与高斯坐标的转换
  5. supermap许可 (*.lic9d)
  6. 服务器系统盘单独硬盘,我的服务器今天加了个硬盘,可以实现双系统吗?
  7. SQL Server 数据库原理与应用
  8. SpringAop通知
  9. 拓展深度学习一种变相的马尔可夫链
  10. Ganglia 权威指南-安装Ganglia过程