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

相关文章

mapstruct中的@Mapper注解的基本用法

《mapstruct中的@Mapper注解的基本用法》在MapStruct中,@Mapper注解是核心注解之一,用于标记一个接口或抽象类为MapStruct的映射器(Mapper),本文给大家介绍ma... 目录1. 基本用法2. 常用属性3. 高级用法4. 注意事项5. 总结6. 编译异常处理在MapSt

MySQL 设置AUTO_INCREMENT 无效的问题解决

《MySQL设置AUTO_INCREMENT无效的问题解决》本文主要介绍了MySQL设置AUTO_INCREMENT无效的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录快速设置mysql的auto_increment参数一、修改 AUTO_INCREMENT 的值。

关于跨域无效的问题及解决(java后端方案)

《关于跨域无效的问题及解决(java后端方案)》:本文主要介绍关于跨域无效的问题及解决(java后端方案),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录通用后端跨域方法1、@CrossOrigin 注解2、springboot2.0 实现WebMvcConfig

Go语言中泄漏缓冲区的问题解决

《Go语言中泄漏缓冲区的问题解决》缓冲区是一种常见的数据结构,常被用于在不同的并发单元之间传递数据,然而,若缓冲区使用不当,就可能引发泄漏缓冲区问题,本文就来介绍一下问题的解决,感兴趣的可以了解一下... 目录引言泄漏缓冲区的基本概念代码示例:泄漏缓冲区的产生项目场景:Web 服务器中的请求缓冲场景描述代码

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

解决JSONField、JsonProperty不生效的问题

《解决JSONField、JsonProperty不生效的问题》:本文主要介绍解决JSONField、JsonProperty不生效的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录jsONField、JsonProperty不生效javascript问题排查总结JSONField

github打不开的问题分析及解决

《github打不开的问题分析及解决》:本文主要介绍github打不开的问题分析及解决,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、找到github.com域名解析的ip地址二、找到github.global.ssl.fastly.net网址解析的ip地址三

MySQL版本问题导致项目无法启动问题的解决方案

《MySQL版本问题导致项目无法启动问题的解决方案》本文记录了一次因MySQL版本不一致导致项目启动失败的经历,详细解析了连接错误的原因,并提供了两种解决方案:调整连接字符串禁用SSL或统一MySQL... 目录本地项目启动报错报错原因:解决方案第一个:第二种:容器启动mysql的坑两种修改时区的方法:本地

springboot加载不到nacos配置中心的配置问题处理

《springboot加载不到nacos配置中心的配置问题处理》:本文主要介绍springboot加载不到nacos配置中心的配置问题处理,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录springboot加载不到nacos配置中心的配置两种可能Spring Boot 版本Nacos

Java中JSON格式反序列化为Map且保证存取顺序一致的问题

《Java中JSON格式反序列化为Map且保证存取顺序一致的问题》:本文主要介绍Java中JSON格式反序列化为Map且保证存取顺序一致的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录背景问题解决方法总结背景做项目涉及两个微服务之间传数据时,需要提供方将Map类型的数据序列化为co