JPA外键映射注解导致的性能问题

2024-08-24 05:12

本文主要是介绍JPA外键映射注解导致的性能问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在项目中遇到了Ajax调用后端方法时反应过慢的问题。到了后端查看接口,发现是使用实体类进行直接查询,接口走完之后控制台又打出了很多sql,说明在执行完当前接口后,程序还未结束,又在继续执行其他的操作。于是想到接口完成后执行的部分才是真正影响性能的地方,仔细查看了一下数据库表结构,发现该表存在外键关联,查看实体类后,在实体类中发现了如下注解

@OneToMany(cascade = CascadeType.ALL, fetch = FetchType.LAZY)
public Set<Location> getLocations() {return this.Locations;}

此注解是用来做外键关联的,表示一个实体可以拥有多个其他实体的实例,用来处理数据库中一对多的关系,他存在几个属性

cascade属性:(1)不定义,则对关系表不会产生任何影响(2CascadeType.PERSIST 级联新建(3CascadeType.REMOVE 级联删除(4CascadeType.REFRESH 级联刷新(5CascadeType.MERGE 级联更新(6CascadeType.ALL 表示同时选择上面四种fetch属性:
定义关联属性何时进行加载:(1FetchType.EAGER:表示关系类在主类加载的时候同时加载(2FetchType.LAZY:表示关系类在被访问时才加载,默认值是 FetchType.LAZYmappedBy属性:(1)拥有关联关系的字段,如果关系是单向的就不需要;如果是双向关系表,那么拥有关系的这一方有建立、解除和更新与另一方关系的能力;而另一方没有这种能力,只能被动管理;这个属性被定义在关系的被拥有方。支持双向 @OneToOne,双向 @OneToMany,双向 @ManyToMany。orphanRemoval属性:(1)指定在删除一方(One)数据的同时是否删除掉多方(Many)的数据。默认为 false,不删除多方(Many)数据;仅仅将一方(One)和连接表的数据进行删除。例如:一个主记录包含三条副记录targetEntity属性:(1)关联目标的实体类,一般不需要写,JPA可以自动识别

于是根据上面的注解属性我们得知了问题根本原因,由于我使用的是JPA的实体类查询方法,会直接通过某些条件获取实体类所有字段,相当于sql中的select *,而此处使用了cascadeType.ALL和fetchType.EAGER,表示在加载实体类时同时将其关联的所有实体加载出来,由于该表外键所关联的信息极多且泛型里字段也多,因此在加载外键关联的时候浪费了大量的时间(前端并不需要关联的实体类),造成了性能问题。
解决方法可以使用sql直接查询固定字段返回到前端,这样不涉及到外键关联字段的查询也就不会触发注解的加载。还有就是将fetch的属性修改为FetchType.LAZY,表示在需要的时候才去加载,也就是你直接去访问的时候程序会自动去加载这些信息,而不是查询的时候不管需不需要直接将所有关联查询出来,这样自然耗费很多时间!

这篇关于JPA外键映射注解导致的性能问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1101538

相关文章

Vue3绑定props默认值问题

《Vue3绑定props默认值问题》使用Vue3的defineProps配合TypeScript的interface定义props类型,并通过withDefaults设置默认值,使组件能安全访问传入的... 目录前言步骤步骤1:使用 defineProps 定义 Props步骤2:设置默认值总结前言使用T

SpringBoot 获取请求参数的常用注解及用法

《SpringBoot获取请求参数的常用注解及用法》SpringBoot通过@RequestParam、@PathVariable等注解支持从HTTP请求中获取参数,涵盖查询、路径、请求体、头、C... 目录SpringBoot 提供了多种注解来方便地从 HTTP 请求中获取参数以下是主要的注解及其用法:1

深度解析Java @Serial 注解及常见错误案例

《深度解析Java@Serial注解及常见错误案例》Java14引入@Serial注解,用于编译时校验序列化成员,替代传统方式解决运行时错误,适用于Serializable类的方法/字段,需注意签... 目录Java @Serial 注解深度解析1. 注解本质2. 核心作用(1) 主要用途(2) 适用位置3

SpringBoot路径映射配置的实现步骤

《SpringBoot路径映射配置的实现步骤》本文介绍了如何在SpringBoot项目中配置路径映射,使得除static目录外的资源可被访问,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一... 目录SpringBoot路径映射补:springboot 配置虚拟路径映射 @RequestMapp

Web服务器-Nginx-高并发问题

《Web服务器-Nginx-高并发问题》Nginx通过事件驱动、I/O多路复用和异步非阻塞技术高效处理高并发,结合动静分离和限流策略,提升性能与稳定性... 目录前言一、架构1. 原生多进程架构2. 事件驱动模型3. IO多路复用4. 异步非阻塞 I/O5. Nginx高并发配置实战二、动静分离1. 职责2

从原理到实战解析Java Stream 的并行流性能优化

《从原理到实战解析JavaStream的并行流性能优化》本文给大家介绍JavaStream的并行流性能优化:从原理到实战的全攻略,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的... 目录一、并行流的核心原理与适用场景二、性能优化的核心策略1. 合理设置并行度:打破默认阈值2. 避免装箱

解决升级JDK报错:module java.base does not“opens java.lang.reflect“to unnamed module问题

《解决升级JDK报错:modulejava.basedoesnot“opensjava.lang.reflect“tounnamedmodule问题》SpringBoot启动错误源于Jav... 目录问题描述原因分析解决方案总结问题描述启动sprintboot时报以下错误原因分析编程异js常是由Ja

深度剖析SpringBoot日志性能提升的原因与解决

《深度剖析SpringBoot日志性能提升的原因与解决》日志记录本该是辅助工具,却为何成了性能瓶颈,SpringBoot如何用代码彻底破解日志导致的高延迟问题,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言第一章:日志性能陷阱的底层原理1.1 日志级别的“双刃剑”效应1.2 同步日志的“吞吐量杀手”

MySQL 表空却 ibd 文件过大的问题及解决方法

《MySQL表空却ibd文件过大的问题及解决方法》本文给大家介绍MySQL表空却ibd文件过大的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录一、问题背景:表空却 “吃满” 磁盘的怪事二、问题复现:一步步编程还原异常场景1. 准备测试源表与数据

Java利用@SneakyThrows注解提升异常处理效率详解

《Java利用@SneakyThrows注解提升异常处理效率详解》这篇文章将深度剖析@SneakyThrows的原理,用法,适用场景以及隐藏的陷阱,看看它如何让Java异常处理效率飙升50%,感兴趣的... 目录前言一、检查型异常的“诅咒”:为什么Java开发者讨厌它1.1 检查型异常的痛点1.2 为什么说