Spring Data JPA知识 day06

一、JPA中的一对多 1.1 示例分析 在不考虑兼职的情况下,公司和员工的关系即为一对多。 1.2 表关系建立         在一对多关系中,我们习惯把一的一方称之为主表,把多的一方称之为从表。在数据库中建立一对多的关系,需要使用数据库的外键约束。         什么是外键?         指的是从表中有一列,取值参照主表的主键,这一列就是外键。 1.3 实体类关系建立以及映射配置         在实体类中,由于客户是少的一方,它应该包含多个联系人,所以实体类要体现出客户中有多个联系人的信息,代码如下:           Spring Data JPA知识 day06         由于联系人是多的一方,在实体类中要体现出,每个联系人只能对应一个客户,代码如下:           Spring Data JPA知识 day06 1.4 映射的注解说明 @OneToMany:      作用:建立一对多的关系映射      属性:              targetEntityClass:指定多的一方的类的字节码              mappedBy:指定从表实体类中引用主表对象的名称。              cascade:指定要使用的级联操作              fetch:指定是否采用延迟加载              orphanRemoval:是否使用孤儿删除 @ManyToOne     作用:建立多对一的关系     属性:              targetEntityClass:指定一的一方实体类字节码              cascade:指定要使用的级联操作              fetch:指定是否采用延迟加载              optional:关联是否可选。如果设置为false,则必须始终存在非空关系。 @JoinColumn      作用:用于定义主键字段和外键字段的对应关系。      属性:              name:指定外键字段的名称              referencedColumnName:指定引用主表的主键字段名称              unique:是否唯一。默认值不唯一              nullable:是否允许为空。默认值允许。              insertable:是否允许插入。默认值允许。              updatable:是否允许更新。默认值允许。              columnDefinition:列的定义信息。 1.5 一对多的操作 1.5.1 添加           Spring Data JPA知识 day06           Spring Data JPA知识 day06         通过保存的案例,我们可以发现在设置了双向关系之后,会发送两条insert语句,一条多余的update语句,那我们的解决是思路很简单,就是一的一方放弃维护权:           Spring Data JPA知识 day06 1.5.2 删除           Spring Data JPA知识 day06 删除操作的说明如下:         删除从表数据:可以随时任意删除。 删除主表数据:     * 有从表数据           1、在默认情况下,它会把外键字段置为null,然后删除主表数据。如果在数据库的表结构上,外键字段有非空约束,默认情况就会报错了。           2、如果配置了放弃维护关联关系的权利,则不能删除(与外键字段是否允许为null,没有关系)因为在删除时,它根本不会去更新从表的外键字段了。           3、如果还想删除,使用级联删除引用     * 没有从表数据引用:随便删         在实际开发中,级联删除请慎用!(在一对多的情况下) 1.5.3 级联操作:指操作一个对象同时操作它的关联对象         使用方法:只需要在操作主体的注解上配置cascade           Spring Data JPA知识 day06 二、JPA中的多对多 2.1 示例分析:用户和角色之间的关系是多对多。 2.2 表关系建立:         多对多的表关系建立靠的是中间表,其中用户表和中间表的关系是一对多,角色表和中间表的关系也是一对多,如下图所示:           Spring Data JPA知识 day06 2.3 实体类关系建立以及映射配置         一个用户可以具有多个角色,所以在用户实体类中应该包含多个角色的信息,代码如下:           Spring Data JPA知识 day06         一个角色可以赋予多个用户,所以在角色实体类中应该包含多个用户的信息,代码如下:           Spring Data JPA知识 day06 2.4 映射的注解说明 @ManyToMany      作用:用于映射多对多关系      属性:               cascade:配置级联操作。               fetch:配置是否采用延迟加载。               targetEntity:配置目标的实体类。映射多对多的时候不用写。 @JoinTable     作用:针对中间表的配置     属性:              nam:配置中间表的名称              joinColumns:中间表的外键字段关联当前实体类所对应表的主键字段                                                                  inverseJoinColumn:中间表的外键字段关联对方表的主键字段              @JoinColumn     作用:用于定义主键字段和外键字段的对应关系。     属性:              name:指定外键字段的名称              referencedColumnName:指定引用主表的主键字段名称              unique:是否唯一。默认值不唯一              nullable:是否允许为空。默认值允许。              insertable:是否允许插入。默认值允许。              updatable:是否允许更新。默认值允许。              columnDefinition:列的定义信息。 2.5 多对多的操作 2.5.1 保存           Spring Data JPA知识 day06         在多对多(保存)中,如果双向都设置关系,意味着双方都维护中间表,都会往中间表插入数据,中间表的2个字段又作为联合主键,所以报错,主键重复,解决保存失败的问题:只需要在任意一方放弃对中间表的维护权即可,推荐在被动的一方放弃,配置如下:           Spring Data JPA知识 day06 2.5.2 删除 三、Spring Data JPA中的多表查询 3.1 对象导航查询         对象图导航检索方式是根据已经加载的对象,导航到他的关联对象。它利用类与类之间的关系来检索对象。例如:我们通过ID查询方式查出一个客户,可以调用Customer类中的getLinkMans()方法来获取该客户的所有联系人。对象导航查询的使用要求是:两个对象之间必须存在关联关系。
上一篇:我选择了MySQL和SpringData JPA


下一篇:SpringMVC源码总结(一)HandlerMapping和HandlerAdapter入门