Spring Data JPA知识 day06

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

小陈工

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值