亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

使用SpringBoot和JPA實現(xiàn)批量處理新增、修改

 更新時間:2023年06月26日 10:37:09   作者:procedure?rabbit  
最近項目需要在JPA中使用ID進行批量更新,所以下面這篇文章主要給大家介紹了關于使用SpringBoot和JPA實現(xiàn)批量處理新增、修改的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下

jpa的sava與saveAll

save()方法

 @Transactional
    public <S extends T> S save(S entity) {
        if (this.entityInformation.isNew(entity)) {
            this.em.persist(entity);
            return entity;
        } else {
            return this.em.merge(entity);
        }
    }

根據(jù)源碼我們可以看出來,save是先通過判斷這個對象是不是新的,新的便會新增,否則就是執(zhí)行的修改。整個是有分兩步進行的,先查詢再新增

saveAll()方法

  @Transactional
    public <S extends T> List<S> saveAll(Iterable<S> entities) {
        Assert.notNull(entities, "The given Iterable of entities not be null!");
        List<S> result = new ArrayList();
        Iterator var3 = entities.iterator();
        while(var3.hasNext()) {
            S entity = var3.next();
            result.add(this.save(entity));
        }
        return result;
    }

saveAll()方法是一種更新多條的一種方式,里面?zhèn)鞯拇鎸ο蟮募?。分析源碼我們可以看出saveAll()底層還是調(diào)用的save()方法,也就是每次需要先查詢再做修改。在使用上方便,但是因每次涉及到查詢、新增,事務的關系,導致修改或者新增耗時得非常的久。

那么下面我們將結合EntityManager對批量新增,修改做出優(yōu)化。

jpa結合Batch

配置文件

spring:
  #配置 Jpa
  jpa:
    properties:
      hibernate:
        generate_statistics: false
        order_insert: true    //配置批量新增
        order_update: true    //配置批量修改
        dialect: org.hibernate.dialect.MySQL5InnoDBDialect
        jdbc:
          batch_size: 1000    //容器內(nèi)批量的大小
    open-in-view: true

EntityManager

EntityManager其實就是一個容器,通過注解引入EntityManager對象 使用EntityManager對新增,修改進行批量處理

/**
 * @author 程序員panda
 * @date 
 * @desc 批量處理
 */
@Service
@Transactional
public class BatchService {
    @PersistenceContext
    private EntityManager entityManager;
	//配置文件中每次批量提交的數(shù)量
    @Value("${spring.jpa.properties.hibernate.jdbc.batch_size}")
    private long batchSize;
    /**
     * 批量插入
     *
     * @param list 實體類集合
     * @param <T>  表對應的實體類
     */
    public <T> void batchInsert(List<T> list) {
        if (!ObjectUtils.isEmpty(list)){
            for (int i = 0; i < list.size(); i++) {
                entityManager.persist(list.get(i));
                if (i % batchSize == 0) {
                    entityManager.flush();
                    entityManager.clear();
                }
            }
            entityManager.flush();
            entityManager.clear();
        }
    }
    /**
     * 批量更新
     *
     * @param list 實體類集合
     * @param <T>  表對應的實體類
     */
    public <T> void batchUpdate(List<T> list) {
        if (!ObjectUtils.isEmpty(list)){
            for (int i = 0; i < list.size(); i++) {
                entityManager.merge(list.get(i));
                if (i % batchSize == 0) {
                    entityManager.flush();
                    entityManager.clear();
                }
            }
            entityManager.flush();
            entityManager.clear();
        }
    }
}

實際運用

選擇一個需要新增的table,將原有的saveAll(),改為調(diào)用自定義的batchInsert()方法

 public JSONObject sumbitPhone(MultipartFile phoneFile) {
        long timeIdStart = System.currentTimeMillis();
        JSONObject result=new JSONObject();
        List<CheckPhone> phoneList=getPhoneListEn(phoneFile);
        batchService.batchInsert(phoneList);
        result.put("code",200);
        result.put("msg","提交成功");
        logger.info("提交預校驗數(shù)據(jù)用時:"+(System.currentTimeMillis() - timeIdStart) / 1000.0+"秒");
        return result;
    }

注意

使用batch批量新增的時候,表的主鍵不能使用自增的形式,需要使用uuid來才能使用批量的新增

運行時間對比

使用saveall()方法耗時(提交1000個號碼文件) 從sql監(jiān)控中可以看到,新增1000個號碼,執(zhí)行了7.962秒,執(zhí)行了1000次的事務,都是一個個提交的

使用batch批量新增(同為1000個號碼)此時執(zhí)行,提交了兩次,執(zhí)行了兩次事務。因為我設置了batch_size為1000。此時用是196毫秒。看一看出他是按999條數(shù)據(jù),然后統(tǒng)一提交的

總結

到此這篇關于使用SpringBoot和JPA實現(xiàn)批量處理新增、修改的文章就介紹到這了,更多相關SpringBoot JPA批量處理新增修改內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • java.security.egd?作用詳解

    java.security.egd?作用詳解

    這篇文章主要為大家介紹了java.security.egd作用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-08-08
  • Spring Data JPA中的動態(tài)查詢實例

    Spring Data JPA中的動態(tài)查詢實例

    本篇文章主要介紹了詳解Spring Data JPA中的動態(tài)查詢。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • 關于@Entity和@Table注解的用法詳解

    關于@Entity和@Table注解的用法詳解

    這篇文章主要介紹了關于@Entity和@Table注解的用法詳解,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 探索分析Redis?AOF日志與數(shù)據(jù)持久性

    探索分析Redis?AOF日志與數(shù)據(jù)持久性

    這篇文章主要為大家介紹了探索分析Redis?AOF日志與數(shù)據(jù)持久性詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12
  • StringBuilder為什么線程不安全深入講解

    StringBuilder為什么線程不安全深入講解

    這篇文章主要給大家介紹了關于StringBuilder為什么線程不安全的相關資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用StringBuilder線程具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2019-08-08
  • MybatisGenerator文件生成不出對應文件的問題

    MybatisGenerator文件生成不出對應文件的問題

    本文介紹了使用MybatisGenerator生成文件時遇到的問題及解決方法,主要步驟包括檢查目標表是否存在、是否能連接到數(shù)據(jù)庫、配置生成器的路徑等,通過在項目結構中引入相應的jar包,并在GeneratorSqlmap.java文件中運行,可以成功生成對應的文件
    2025-01-01
  • Springboot FeignClient調(diào)用Method has too many Body parameters解決

    Springboot FeignClient調(diào)用Method has too m

    本文主要介紹了Springboot FeignClient微服務間調(diào)用Method has too many Body parameters 解決,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12
  • SpringBoot3整合Hutool-captcha實現(xiàn)圖形驗證碼

    SpringBoot3整合Hutool-captcha實現(xiàn)圖形驗證碼

    在整合技術框架的時候,想找一個圖形驗證碼相關的框架,看到很多驗證碼的maven庫不再更新了或中央倉庫下載不下來,還需要多引入依賴,后面看到了Hutool圖形驗證碼(Hutool-captcha)中對驗證碼的實現(xiàn),所以本文介紹了SpringBoot3整合Hutool-captcha實現(xiàn)圖形驗證碼
    2024-11-11
  • 使用maven打包生成doc文檔和打包源碼

    使用maven打包生成doc文檔和打包源碼

    這篇文章主要介紹了使用maven打包生成doc文檔和打包源碼的實現(xiàn),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • Java實現(xiàn)視頻初步壓縮和解壓的代碼示例

    Java實現(xiàn)視頻初步壓縮和解壓的代碼示例

    從攝像頭讀取每一幀的圖片,用一些簡單的方法將多張圖片信息壓縮到一份文件中(自定義的視頻文件),自定義解碼器讀取視頻文件,并將每幀圖片展示成視頻,本文主要介紹了Java實現(xiàn)視頻初步壓縮和解壓,需要的朋友可以參考下
    2023-10-10

最新評論