hibernate一对多关联映射及关联映射注解

单向多对一关联映射

语法:
需要在“多”的一方(主动方)的持久化类中声明一个“一”方(被动方)类型的成员变量,并定义对应该变量的属性(关联属性)的setter和getter方法。
在“多”的一方的映射文件中使用来定义关联关系及关联属性,并在其中使用column属性设置指向被动方主键的关联外键。
在测试类中调用关联属性的setter方法设置外键值。

单向一对多关联映射

语法:
在“一”的一方(主动方)的持久化类中声明一个元素为“多”方(被动方)类型的集合成员变量,并定义对应该集合变量的属性(关联属性)的setter和getter方法。
在主动方的映射文件中使用设置关联属性。
在标记对之间使用设置被动方映射表中的外键字段名(对应主动方映射表主键)。
使用来定义关联关系。
可在中使用cascade属性设置级联操作(可选)
在测试类中调用关联属性的getter方法添加集合元素设置外键值。

双向一对多关联映射

语法:
同时应用单向一对多和单向多对一关联的语法
可在一对多关联的配置中设置控制反转:在中设置属性inverse=“true”可将控制权由“一”方转给“多”方(可选)

关联关系映射注解

@OneToMany(targetEntity=所关联的类名.class,cascade=CascadeType.枚举值|mappedBy=关联关系维护的关联属性名, fetch=FetchType.枚举值)

关联属性的类型如果可由变量或访问器确定时,可以省略targetEntity属性。
CascadeType可取的枚举值有:ALL、REMOVE、 PERSIST等值。
mappedBy属性用于指定由哪个持久化类中的关联属性来维护关联关系。当设置了这个属性时,不能设置cascade属性。
fetch属性指定何时获取被动方对象,可取的枚举值为:EAGER和LAZY,默认值为LAZY

在这里插入图片描述

@ManyToOne(targetEntity=所关联的名.class, cascade=CascadeType.枚举值, optional= true|false,fetch=FetchType.枚举值)

optional表示主动方对象存在时,被动方对象是否必须存在,默认值为true,表示被动方对象可以不存在。
该注解没有mappedBy属性。
fetch属性指定何时获取被动方对象,可取的枚举值为:EAGER和LAZY,默认值为EAGER。

在这里插入图片描述

@OneToOne(targetEntity=所关联的类名.class,cascade=CascadeType.枚举值|mappedBy=关联关系维护的关联属性名, optional=true|false,fetch=FetchType.枚举值)

fetch属性指定何时获取被动方对象,可取的枚举值为:EAGER和LAZY,默认值为EAGER。
在这里插入图片描述
在这里插入图片描述

@ManyToMany(targetEntity=所关联的类名.class,cascade=CascadeType.枚举值|mappedBy=关联关系维护的关联属性名, fetch=FetchType.枚举值)

fetch属性指定何时获取被动方对象,可取的枚举值为:EAGER和LAZY,默认值为LAZY。
在这里插入图片描述
在这里插入图片描述

@JoinColumn(name=外键字段名, unique=true|false,nullable=true|false, insertable=true|false,updatable=true|false)

该注解用于设置外键字段相关信息。
unique、nullable、insertable和updatable默认值都为true。
不设置该注解时,默认生成的外键字段名为:关联属性_id
在这里插入图片描述

@JoinTable(name=“中间表名”, joinColumns={@JoinColumn(name=“主动方映射的外键字段名”)}, inverseJoinColumns={ @JoinColumn(name = “被动方映射的外键字段名”) },…)

该注解用于设置中间表相关信息。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Hibernate是一个Java持久化框架,它能够将Java对象映射到数据库的表格,同时支持各种关系数据库,如MySQL、Oracle等。在Hibernate,对于一对一、一对多和多对多的关系,我们可以通过以下方式进行映射。 一对一关系:在Hibernate,可以通过主键关联和外键关联来实现一对一关系的映射。主键关联是指两个实体之间的关联通过主键来进行,可以使用@PrimaryKeyJoinColumn注解将两个实体关联起来。外键关联是指通过一个实体引用另一个实体的主键作为外键,使用@JoinColumn注解来指定外键属性一对多关系:在Hibernate一对多关系通常通过外键关联来实现。在一的一方,使用@OneToMany注解来定义一对多关系,同时使用@JoinColumn注解指定外键属性。在多的一方,使用@ManyToOne注解来定义多对一关系,并使用@JoinColumn注解指定外键属性。 多对多关系:在Hibernate,多对多关系通常通过间表来实现。在多对多的两个实体使用@ManyToMany注解来定义多对多关系。同时,需要在间表创建两个外键,分别与两个实体的主键关联,并使用@JoinTable注解来指定间表的表名和两个外键的列名。 总结:通过Hibernate注解方式,可以方便地实现一对一、一对多和多对多关系的映射。通过合理地使用注解,可以减少编写映射文件的工作量,提高开发效率。同时,Hibernate还提供了在运行时自动生成表结构的功能,可以根据Java实体类来动态创建或更新对应的数据库表格,从而提高系统的可维护性和灵活性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一峰说

坚持价值输出

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值