使用JPA查询时内存飙升不降问题

问题原因:jpa一级缓存查询大量数据结果缓存导致内存占用

处理方式:

首先在方法上加上@Transactional 注解,很重要

import javax.annotation.Resource;
import javax.persistence.EntityManager;
import  org.hibernate.Session;

@Resource
private EntityManager entityManager;

entityManager.clear();

同样mybatisplus清除一级缓存:

sqlSession.clearCache();

注意:重点在这,

如果在 entityManager.clear() 之前有jpa更新操作,就会出现更新失效问题,保存一个实体可以通过 CrudRepository.save(...)-Method执行。它将使用底层的JPA EntityManager持久化或合并给定的 实体。如果实体没有保留 ,Spring Data JPA将通过调用 entityManager.persist(...)方法来保存该实体,否则将调用 entityManager.merge(...)方法。

因此,以上方案就会有问题,就需要手动提交事物,再清除缓存

import org.springframework.transaction.PlatformTransactionManager;
import org.springframework.transaction.TransactionDefinition;
import org.springframework.transaction.TransactionStatus;
public class Test{	
    @Resource
	private EntityManager entityManager;
	@Resource
    private PlatformTransactionManager platformTransactionManager;
	@Resource
    private TransactionDefinition transactionDefinition;

    public void test(){
        TransactionStatus transactionStatus = platformTransactionManager.getTransaction(transactionDefinition);
   
        try{
           /***逻辑处理***/
           platformTransactionManager.commit(transactionStatus);
		}catch (Exception e) {
			platformTransactionManager.rollback(transactionStatus);
		}
		entityManager.clear();
		System.gc();
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值