zoukankan      html  css  js  c++  java
  • springBoot事务失效导致批量插入性能巨幅降低

        @Override
        public void savePatientAndSeekMedical(){
            long start = System.currentTimeMillis();
    //        ((PatientService) AopContext.currentProxy()).saveBatch(patients, 1000);
    //        saveBatch(patients, 1000);
            SpringUtil.getBean(this.getClass()).saveBatch(patients, 1000);
    //        patientMapper.saveBatchBySql(patients);
    //        seekMedicalService.saveBatch(seekMedicals, 1000);
            log.warn("保存" + patients.size() + "条患者数据,用时:" + (System.currentTimeMillis() - start) + "ms");
            patients.clear();
            seekMedicals.clear();
        }

    这段代码里面使用了三种方式保存患者数据

    第一种 ((PatientService) AopContext.currentProxy()).saveBatch(patients, 1000); 方式在这里会抛出Cannot find current proxy: Set 'exposeProxy' property on Advised to 'true' to make it available异常,猜测原因是saveBatch是mybatisPlus的方法,普通情况如果需要在在该方法上做切面可以用该方式

    第二种 saveBatch(patients, 1000); 会导致性能巨慢 导入2w调数据需要900秒左右

    第三种 SpringUtil.getBean(this.getClass()).saveBatch(patients, 1000); 可以保证事务并且性能非常好(2w条数据大概15秒左右)

    贴上SpringUtil代码

    package cn.rivamed.fhvc.util;
    
    import org.springframework.beans.BeansException;
    import org.springframework.context.ApplicationContext;
    import org.springframework.context.ApplicationContextAware;
    import org.springframework.core.env.Environment;
    import org.springframework.stereotype.Component;
    
    @Component
    public class SpringUtil implements ApplicationContextAware {
    
        private static ApplicationContext applicationContext = null;
    
        @Override
        public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
            SpringUtil.applicationContext = applicationContext;
        }
    
        public static <T> T getBean(Class<T> cla) {
            return applicationContext.getBean(cla);
        }
    
        public static <T> T getBean(String name, Class<T> cal) {
            return applicationContext.getBean(name, cal);
        }
    
        public static Object getBean(String name){
            return applicationContext.getBean(name);
        }
    
        public static String getProperty(String key) {
            return applicationContext.getBean(Environment.class).getProperty(key);
        }
    }
  • 相关阅读:
    undefined symbol 问题解决记录
    2021年中国数字人民币发展研究报告
    如何画出优秀的架构图
    用SIKT模型,让用户画像效果倍增
    全面总结图表设计
    如何用一周了解一个行业
    未来社区解决方案
    增长4大阶段,实现营销倍增的核心法则
    裂变营销的3个层次,让你实现指数增长
    运营的3个层面,让你轻松获得忠实用户
  • 原文地址:https://www.cnblogs.com/guanxiaohe/p/11818372.html
Copyright © 2011-2022 走看看