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

相关文章

mybatis和mybatis-plus设置值为null不起作用问题及解决

《mybatis和mybatis-plus设置值为null不起作用问题及解决》Mybatis-Plus的FieldStrategy主要用于控制新增、更新和查询时对空值的处理策略,通过配置不同的策略类型... 目录MyBATis-plusFieldStrategy作用FieldStrategy类型每种策略的作

linux下多个硬盘划分到同一挂载点问题

《linux下多个硬盘划分到同一挂载点问题》在Linux系统中,将多个硬盘划分到同一挂载点需要通过逻辑卷管理(LVM)来实现,首先,需要将物理存储设备(如硬盘分区)创建为物理卷,然后,将这些物理卷组成... 目录linux下多个硬盘划分到同一挂载点需要明确的几个概念硬盘插上默认的是非lvm总结Linux下多

Springboot中分析SQL性能的两种方式详解

《Springboot中分析SQL性能的两种方式详解》文章介绍了SQL性能分析的两种方式:MyBatis-Plus性能分析插件和p6spy框架,MyBatis-Plus插件配置简单,适用于开发和测试环... 目录SQL性能分析的两种方式:功能介绍实现方式:实现步骤:SQL性能分析的两种方式:功能介绍记录

在 Spring Boot 中使用 @Autowired和 @Bean注解的示例详解

《在SpringBoot中使用@Autowired和@Bean注解的示例详解》本文通过一个示例演示了如何在SpringBoot中使用@Autowired和@Bean注解进行依赖注入和Bean... 目录在 Spring Boot 中使用 @Autowired 和 @Bean 注解示例背景1. 定义 Stud

Python Jupyter Notebook导包报错问题及解决

《PythonJupyterNotebook导包报错问题及解决》在conda环境中安装包后,JupyterNotebook导入时出现ImportError,可能是由于包版本不对应或版本太高,解决方... 目录问题解决方法重新安装Jupyter NoteBook 更改Kernel总结问题在conda上安装了

pip install jupyterlab失败的原因问题及探索

《pipinstalljupyterlab失败的原因问题及探索》在学习Yolo模型时,尝试安装JupyterLab但遇到错误,错误提示缺少Rust和Cargo编译环境,因为pywinpty包需要它... 目录背景问题解决方案总结背景最近在学习Yolo模型,然后其中要下载jupyter(有点LSVmu像一个

解决jupyterLab打开后出现Config option `template_path`not recognized by `ExporterCollapsibleHeadings`问题

《解决jupyterLab打开后出现Configoption`template_path`notrecognizedby`ExporterCollapsibleHeadings`问题》在Ju... 目录jupyterLab打开后出现“templandroidate_path”相关问题这是 tensorflo

如何解决Pycharm编辑内容时有光标的问题

《如何解决Pycharm编辑内容时有光标的问题》文章介绍了如何在PyCharm中配置VimEmulator插件,包括检查插件是否已安装、下载插件以及安装IdeaVim插件的步骤... 目录Pycharm编辑内容时有光标1.如果Vim Emulator前面有对勾2.www.chinasem.cn如果tools工

最长公共子序列问题的深度分析与Java实现方式

《最长公共子序列问题的深度分析与Java实现方式》本文详细介绍了最长公共子序列(LCS)问题,包括其概念、暴力解法、动态规划解法,并提供了Java代码实现,暴力解法虽然简单,但在大数据处理中效率较低,... 目录最长公共子序列问题概述问题理解与示例分析暴力解法思路与示例代码动态规划解法DP 表的构建与意义动

Java多线程父线程向子线程传值问题及解决

《Java多线程父线程向子线程传值问题及解决》文章总结了5种解决父子之间数据传递困扰的解决方案,包括ThreadLocal+TaskDecorator、UserUtils、CustomTaskDeco... 目录1 背景2 ThreadLocal+TaskDecorator3 RequestContextH