SpringBoot结合SpringData Jpa--注解部分(三)

SpringBoot结合SpringData Jpa–注解部分(三)

承接上篇博客:https://blog.youkuaiyun.com/qq_33608923/article/details/102792383
上篇主要讲了@ManyToMany和@OneToOne两个注解,遗留了一个问题,就是在实体关系为一对多或者多对多的时候,hibernate会先执行查询主表信息的一条sql,再根据主表外键查询副表的信息,这样就会执行1 + n条sql。
本篇来解决这个问题,Spring Data JPA引入了@NameEntityGraph注解:

import javax.persistence.*;
import java.util.List;

/**
*Permission
*author BenJerry
*version 1.0
*/
@NamedEntityGraph(name = "Permission.roles", attributeNodes = {
        @NamedAttributeNode("roles")
})
@Table(name = "t_permission")
@Entity
public class Permission {
    @Id
    @GeneratedValue(strategy = GenerationType.AUTO)
    private Long id;

    private String permission;

    @ManyToMany
    @JoinTable(name = "t_role_permission", joinColumns = @JoinColumn(name = "pid", referencedColumnName = "id"),
        inverseJoinColumns = @JoinColumn(name = "rid", referencedColumnName = "id"))
    private List<Role> roles;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getPermission() {
        return permission;
    }

    public void setPermission(String permission) {
        this.permission = permission;
    }

    public List<Role> getRoles() {
        return roles;
    }

    public void setRoles(List<Role> roles) {
        this.roles = roles;
    }
}

在PermissionRepository中重写findAll方法:

import com.github.jpa.demo.entity.Permission;
import org.springframework.data.jpa.repository.EntityGraph;
import org.springframework.data.jpa.repository.JpaRepository;

import java.util.List;

/**
 * PermissionRepository
 * author BenJerry
 * version 1.0
 */
public interface PermissionRepository extends JpaRepository<Permission, Long> {

    @Override
    @EntityGraph(value = "Permission.roles")
    List<Permission> findAll();

}

实际执行的sql:

Hibernate: select permission0_.id as id1_1_0_, role2_.id as id1_2_1_, permission0_.permission as permissi2_1_0_, role2_.pid as pid2_2_1_, role2_.role as role3_2_1_, roles1_.pid as pid1_3_0__, roles1_.rid as rid2_3_0__ from t_permission permission0_ left outer join t_role_permission roles1_ on permission0_.id=roles1_.pid left outer join t_role role2_ on roles1_.rid=role2_.id

可以看到jpa一条sql就搞定了,使用的是left outer join,其中 @NamedAttributeNode这个注解可以写多个用以加入更多的表

【2021年,将Spring全家桶系列课程进行Review,修复顺序等错误。进入2022年,将Spring的课程进行整理,整理为案例精讲的系列课程,并新增高级的Spring Security等内容,通过手把手一步步教你从零开始学会应用Spring,课件将逐步进行上传,敬请期待】 本课程是Spring案例精讲课程的第四部分Spring Cloud,Spring案例精讲课程以真实场景、项目实战为导向,循序渐进,深入浅出的讲解Java网络编程,助力您在技术工作中更进一步。 本课程聚焦Spring Cloud的核心知识点:注册中心、服务提供者与消费者、服务的调用OpenFeign、Hystrix监控、服务网关gateway、消息驱动的微服务Spring Cloud Stream、分布式集群、分布式配置中心的案例介绍, 快速掌握Spring Cloud的核心知识,快速上手,为学习及工作做好充足的准备。 由于本课程聚焦于案例,即直接上手操作,对于Spring的原理等不会做过多介绍,希望了解原理等内容的需要通过其他视频或者书籍去了解,建议按照该案例课程一步步做下来,之后再去进一步回顾原理,这样能够促进大家对原理有更好的理解。【通过Spring全家桶,我们保证你能收获到以下几点】 1、掌握Spring全家桶主要部分的开发、实现2、可以使用Spring MVC、Spring Boot、Spring Cloud及Spring Data进行大部分的Spring开发3、初步了解使用微服务、了解使用Spring进行微服务的设计实现4、奠定扎实的Spring技术,具备了一定的独立开发的能力  【实力讲师】 毕业于清华大学软件学院软件工程专业,曾在Accenture、IBM等知名外企任管理及架构职位,近15年的JavaEE经验,近8年的Spring经验,一直致力于架构、设计、开发及管理工作,在电商、零售、制造业等有丰富的项目实施经验  【本课程适用人群】如果你是一定不要错过!  适合于有JavaEE基础的,如:JSP、JSTL、Java基础等的学习者没有基础的学习者跟着课程可以学习,但是需要补充相关基础知识后,才能很好的参与到相关的工作中。 【Spring全家桶课程共包含如下几门】 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值