首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Hibernate之关联关系映射(一对多和多对一映射,多对多映射)

~~~ 1:Hibernate的关联映射,存在一对多和多对一映射,多对多映射:   1.1:一对多和多对一映射,举例说明:      学生和老师:        一个老师可以教多个学生 【一对多映射】...      多个学生可以被一个老师教【多对一映射】     部门与员工:       一个部门有多个员工【一对多映射】       多个员工属于一个部门【多对一映射】 1.2:多对多,举例说明:     ...项目和开发员工:【双向一对多即多对多映射】       一个项目有多个开发人员【一对多】          一个开发人员参与多个项目【一对多】 2:一对多和多对一映射,理清以下思路就可以进行简单的开发了...-- 20 一对多关联映射配置(通过部门管理到员工) 21 Dept映射关键点 22 (1)指定映射的集合属性:""emps...【推荐,在一对多和多对一的关联关系中,保存数据最好是通过多对一来维护关系,这样可以减少update语句的生成,从而提高hibernate的利用效率】                emp1.setDept

4.7K90
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    mybatis关联查询问题(一对多、多对一)

    下面通过一个实例,来展示一下Mybatis对于常见的一对多和多对一关系复杂映射是怎样处理的。 设计一个简单的博客系统,一个用户可以开多个博客,在博客中可以发表文章,允许发表评论,可以为文章加标签。...Tag表:标签表,表示文章的标签分类,一篇文章可以有多个标签,而一个标签可以应用到不同的文章上,所以Tag和Post的关系是多对多的关系;(Tag和Post的多对多关系通过Post_Tag表体现) Post_Tag...Mybatis还支持一种嵌套结果的查询:即对于一对多,多对多,多对一的情况的查询,Mybatis通过联合查询,将结果从数据库内一次性查出来,然后根据其一对多,多对一,多对多的关系和ResultMap中的配置...对于关联的结果查询,如果是多对一的关系,则通过形如 一对多和多对一的映射对象处理。

    5.2K50

    hibernate 一对一,一对多,多对多关联关系使用

    一对一 ? 一对一 如果我们只是单纯的在两个实体类中分别加上@OneToOne注解,会发现两张表都分别引入了对方的主键作为外键。...利用mappedBy属性,指明关系由哪一方维护。 一对多关系处理 创建两个实体对象,分别对应一与多的一方。...加上@JoinColumn属性表结构 扩展 在一对多双方都设置了关联关系后,进行数据存储模拟 @Test public void contextLoads() { OneObject...先插入多的一方数据,然后在把one对应的一方关联加进去。 想要避免这种多余sql。有两种方式。 方法一:直接把one对应的一方赋值给多的一方。...多对多 正常建立两个多对多关系实体 1.多对多实体一 package com.example.demo.entity.manytomany; import java.util.List; import

    5.2K20

    MyBatis关联映射:一对一、一对多总结一二

    一、一对一 场景:生活中每一个人都有一个身份证,这是最简单的一对一的关系。 (1)用户表 ? (2)身份证表 ?...-- 一对一关系映射 --> <association column="card_id" property="card" select="com.xuliugen.mybatis.demo.dao.CardMapper.selectByPrimaryKey..." javaType="com.xuliugen.mybatis.demo.bean.Card"/> 重点在,红色区域的内容: 1、column 表示数据库user表中的字段card_id; 2、property...二、一对多 场景:生活中每一个班级有多个学生,这是最简单的一对多的关系。 (1)学生表 ? 其中,clazz_id 表示班级ID。 (2)班级表 ? (3)班级实体对象 ? (4)学生实体对象 ?...重点在,红色区域的内容: 1、fetchType 表示是否是懒加载,可以选择eager和lazy,正常情况下,一对多关联的结合对象,都设置为懒加载lazy; 2、property 表示User实体对象中的属性

    68810

    JPA规范:一对多、一对一、多对多的双向关联与级联操作以及JPA联合主键

    一、一对多双向关联与级联操作: 以订单类和订单商品类为例: 多的一方为关系维护端,关系维护端负责外键记录的更新,关系被维护端是没有权利更新外键记录。...class JpaDaoImpl implements JpaDao { //事务管理 @PersistenceContext private EntityManager em; //JPA一对多测试类...具体配置步骤可以参看这篇博客:https://blog.csdn.net/a745233700/article/details/81415550 二、一对一双向关联与级联操作: 以身份证类和人为例: 1...: //JPA一对多测试类 @Override public void jpaTest() { Person person=new Person("小张"); person.setIdcard...(new IDcard("448xxx1990xxxx1234")); em.persist(person); } 三、多对多双向关联与级联操作: 以教师类和学生类为例: 1、教师类: //

    3.2K30

    Mybatis【16】-- Mybatis多对一关联查询

    docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 一对多关联查询:每个国家有很多大臣,领导人,现在我们查询一个领导,希望能将他所在国家的信息连带出来...,这就是一对多关联查询。...int mid); } mapper文件最重要的部分,与一对一有点像,两种查询方式,一种是嵌套结果,一种是嵌套查询,嵌套查询可以使用懒加载模式,比较常用: 2" resultMap="countryMapper2"> select mid,mname,...这个世界希望一切都很快,更快,但是我希望自己能走好每一步,写好每一篇文章,期待和你们一起交流。 此文章仅代表自己(本菜鸟)学习积累记录,或者学习笔记,如有侵权,请联系作者核实删除。

    27010

    Mybatis【18】-- Mybatis自关联多对一查询方式

    注:代码已托管在GitHub上,地址是:https://github.com/Damaer/Mybatis-Learning ,项目是mybatis-14-oneself-many2one,需要自取,需要配置...(resultMap),resultMap的id是“newsLabelMapper”,“newsLabelMapper”中除了id映射和name映射,还有一个,里面定义的是关联关系定义...== Total: 1 NewsLabel [id=7, name=北京金瓯, parent=NewsLabel [id=4, name=CBA, parent=NewsLabel [id=2,...name=体育新闻, parent=null]]] 【作者简介】:秦怀,公众号【秦怀杂货店】作者,技术之路不在一时,山高水长,纵使缓慢,驰而不息。...人无完人,文章也一样,文笔稚嫩,在下不才,勿喷,如果有错误之处,还望指出,感激不尽~ - END -

    32930

    Mybatis【17】-- Mybatis自关联查询一对多查询

    docsify文档地址在:https://damaer.github.io/Mybatis-Learning/#/ 所谓自关联查询,是指自己既然充当一方,又充当多方。...在数据表里面实现就是一张表,有一个外键pid,用来表示该栏目的父栏目,一级栏目没有父栏目的,可以将其外键设置为0。...实体类NewsLabel.java,使用一对多的关系: import java.util.Set; public class NewsLabel { private Integer id; private...里面递归调用另一个sql,最外层的sql只执行一次,这样就可以实现查询自身一次,递归查询子孙栏目的功能: 一切都很快,更快,但是我希望自己能走好每一步,写好每一篇文章,期待和你们一起交流。 此文章仅代表自己(本菜鸟)学习积累记录,或者学习笔记,如有侵权,请联系作者核实删除。

    60920

    orm2 中文文档 4.1 hasOne(多对一关系)

    译者:飞龙 来源:hasOne hasOne关联是一种多对一的关系,意思是你定义的模型可以有多个实例指向一个其它的实例(所属相同模型或不同模型)。...association_name [, association_model [, options ] ]); 描述 association_name是两个模型之间的关系名称‘ association_model是要关联的另一个模型...(如果没有定义,假设为同一个模型,大多数情况下这可能不是你想要的); options是一个对象,拥有一些和关联有关的,你可以调整的属性,比如自动获取,再比如表(SQL中)或者集合(MongoDB中)的名称...如果关联并不是必须的,则可以为空。 这个关联也会创建一些额外的便利方法(叫做关联访问器)来帮助你管理它。访问器的名称也可以修改(同上,在选项里面),默认情况下,它们会拥有和关联名称相似的名称。...你可以向关联传递一个选项来实现它。

    41310
    领券