JPA 批量操作性能优化配置

JPA 批量操作性能优化配置

规则说明

本项目使用 Spring Data JPA 进行数据库操作,为提升批量插入和更新的性能,需要启用 Hibernate 的批处理功能。

配置项

以下配置应添加到 application.properties 文件中:

properties 复制代码
# ========== JPA 批量操作性能优化 ==========

# 批量插入时每次批量的大小(默认30)
spring.jpa.properties.hibernate.jdbc.batch_size=1000

# 强制按插入顺序执行更新
spring.jpa.properties.hibernate.order_updates=true

# 对插入语句进行排序,提高批处理效率
spring.jpa.properties.hibernate.jdbc.order_inserts=true

配置说明

配置项 建议值 说明
hibernate.jdbc.batch_size 1000 每次批量插入/更新的记录数。值越大,内存占用越高,但批量效率更高
hibernate.order_updates true 强制按插入顺序执行更新,防止并发更新导致的数据不一致
hibernate.order_inserts true 对插入语句进行排序,提高批处理效率

应用范围

此配置适用于以下场景:

  1. 批量插入 - 一次插入多条记录(如批量创建用户消息、合同审批节点等)
  2. 批量更新 - 一次更新多条记录(如批量删除消息、更新审批状态等)
  3. 大数据量操作 - 处理大量数据时的性能优化

注意事项

  1. 内存占用

    • batch_size 设置过大会增加内存占用
    • 建议根据实际数据量和服务器内存情况调整
  2. 事务边界

    • 批量操作应在同一事务内完成
    • 使用 @Transactional 注解确保事务一致性
  3. 测试验证

    • 修改配置后,测试批量操作的执行结果
    • 确认数据正确性和性能提升

相关业务场景

合同审批流程创建

java 复制代码
// 批量创建审批节点
List<ContractWorkFlow> workFlowNodes = new ArrayList<>();
// ... 添加节点
contractWorkFlowMapper.saveAll(workFlowNodes);  // 使用批量插入

消息批量删除

java 复制代码
// 批量删除审批消息
List<Message> messages = messageMapper.findByBizIdAndIsDeleted(...);
for (Message message : messages) {
    message.setIsDeleted(StatusEnum.Del.getStatus());
    // ...
}
messageMapper.saveAll(messages);  // 使用批量更新

性能对比

场景 未启用批量 启用批量(batch_size=1000)
插入1000条记录 ~5000-10000ms ~1000-2000ms
更新1000条记录 ~3000-8000ms ~3000-600ms

参考链接

相关推荐
jump_jump2 天前
流式 HTML:从 htmx 片段装配到浏览器原生增量渲染
javascript·性能优化·前端工程化
小小工匠3 天前
Redis - 事务机制:能实现 ACID 属性吗
数据结构·redis·性能优化·并发·持久化
大鱼>3 天前
地平线BPU部署实战:YOLOv8在J5/X3上的算法适配与性能优化
算法·yolo·性能优化
醉颜凉3 天前
Elasticsearch高性能优化:Bulk API大规模数据导入性能调优全攻略
elasticsearch·性能优化·jenkins
隔窗听雨眠3 天前
C语言函数递归从入门到精通(下):性能优化与工程实践
c语言·算法·性能优化
昇腾CANN3 天前
【cann-samples系列】GroupedMatmul MX量化矩阵乘的深度性能优化实践
线性代数·性能优化·矩阵·昇腾·cann
霸道流氓气质3 天前
Spring Boot 微服务性能优化完全指南
spring boot·微服务·性能优化
步步为营DotNet4 天前
Blazor 与 Microsoft.Extensions.AI 在客户端性能优化中的协同应用
人工智能·microsoft·性能优化
不能只会打代码4 天前
边缘视频分析平台的架构设计与性能优化——从750ms到190ms的调优之路
java·spring boot·redis·性能优化·边缘计算·物联网竞赛
山东点狮信息科技有限公司4 天前
企业级 MES 制造执行系统架构设计与实践
spring cloud·性能优化·系统架构·策略模式·点狮