欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

如何對(duì)?Excel?表格中提取的數(shù)據(jù)進(jìn)行批量更新

 更新時(shí)間:2024年06月12日 14:25:33   作者:天縱云裳  
這篇文章主要介紹了如何對(duì)Excel表格中提取的數(shù)據(jù)進(jìn)行批量更新操作,本文通過示例代碼介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧

書接上回,這篇文章主要來講述如何對(duì) Excel 表格中提取的數(shù)據(jù)進(jìn)行批量更新操作

一.編寫查詢代碼

目的是根據(jù)工號(hào), 將其對(duì)應(yīng)的 Flag 變?yōu)?1 ,那么 mapper 中我們可以這樣做

//Mapper層
    public int updateFlagByEmployeeID(@Param("ids") List<String> ids);
//XML文件中
    <update id="updateFlagByEmployeeID">
        update OA_JDY_Personnel_Info_Test set enableFlag = 1
        where employeeID in
        <foreach collection="ids" separator="," item="employeeID" open="(" close=")">
            #{employeeID}
        </foreach>
    </update>

二.編寫 Service 層代碼

我們從 String response = " " 往下看,這段代碼之前的在上篇博客解釋了,主要是進(jìn)行數(shù)據(jù)解析

?
    public String enableFlagUpdate(String filename) {
        //獲取 PersonSynData 類的 Class 對(duì)象。
        Class<PersonSynData> head = PersonSynData.class;
        List<PersonSynData> updateList = new ArrayList<>();
        ExcelReader excelReader = EasyExcel.read(filename, head, new AnalysisEventListener<PersonSynData>() {
            @Override
            public void invoke(PersonSynData personSynData, AnalysisContext analysisContext) {
                updateList.add(personSynData);
            }
            @Override
            public void doAfterAllAnalysed(AnalysisContext analysisContext) {
                System.out.println("Excel解析完成......");
            }
        }).build();
        //創(chuàng)建 sheet 對(duì)象,并且讀取Excel的第一個(gè)sheet(下表從0開始),也可以根據(jù) sheet 名稱獲取
        ReadSheet readSheet = EasyExcel.readSheet(0).build();
        //讀取 sheet 表格數(shù)據(jù),參數(shù)是可變參數(shù),也可以讀取多個(gè)sheet
        //這個(gè)操作會(huì)讀取 excel 表格的數(shù)據(jù)
        excelReader.read(readSheet);
        //需要自己關(guān)閉流操作,在讀取文件的時(shí)候會(huì)創(chuàng)建臨時(shí)文件,如果不關(guān)閉的話,會(huì)損耗磁盤
        excelReader.finish();
        String success = "";
        //創(chuàng)建更新集合
        List<String> employeeIDs = new ArrayList<>();
        for(int i = 0; i < updateList.size(); i++){
            //這里可以拿到表格內(nèi)的所有數(shù)據(jù),根據(jù)表格中的員工號(hào),批量修改Flag
            String employeeID = updateList.get(i).getEmployeeID();
            employeeIDs.add(employeeID);
        }
        int totalUpdatedCount = 0;
        for (int i = 0; i < employeeIDs.size(); i += BATCH_SIZE) {
            List<String> batchIds = employeeIDs.subList(i, Math.min(i + BATCH_SIZE, employeeIDs.size()));
            int updatedCount = jdcloudDao.updateFlagByEmployeeID(batchIds);
            totalUpdatedCount += updatedCount;
        }
        //進(jìn)行批量更新 每次只更新 2008條
        //int count = jdcloudDao.updateFlagByEmployeeID(employeeIDs);
        return "更新成功的條數(shù):" + totalUpdatedCount + "<br>";
    }
?

 1. List<String> employeeIDs = new ArrayList<>(); 這段代碼在經(jīng)過下面的 for 循環(huán)后,里面存儲(chǔ)的是每一列的信息,包括 姓名,工號(hào),F(xiàn)lag 

2. 下面的 totalUpdatedCount 是用來記錄更新成功的總條數(shù)

3.List<String> batchIds = employeeIDs.subList(i, Math.min(i + BATCH_SIZE, employeeIDs.size())); 最為關(guān)鍵的代碼就是這個(gè),它的意思是從結(jié)果集合 employeeIDs 中截取指定長(zhǎng)度的元素集合,每次取的都是 i + BATCH_SIZE(2000)大小的元素。舉個(gè)例子,假如出文件中的數(shù)據(jù)有 4200 條

第一次:employeeIDs.subList(0, Math.min(2000, 4200));   截取了 0 ~ 2000的數(shù)據(jù)進(jìn)行更新

第二次:employeeIDs.subList(2000, Math.min(4000, 4200)); 截取了 2000~4000 的數(shù)據(jù)進(jìn)行更新

第三次:employeeIDs.subList(4000, Math.min(6000, 4200)); 截取了 4000 ~ 4200 的數(shù)據(jù)更新

其實(shí)最關(guān)鍵的就是第三次,這段代碼保證了如果最后一次的數(shù)據(jù)不夠  BATCH_SIZE(2000)那么會(huì)截取到末尾的位置,來保證不會(huì)越界。

三.為什么要進(jìn)行批量更新

在Mybatis和SqlServer數(shù)據(jù)源情況下,如果一次更新超過了 2100 條,會(huì)報(bào):The incoming request has too many parameters. The server supports a maximum of 2100 parameters. Reduce the number of parameters and resend the request.; nested exception isxxxx  的錯(cuò)誤

也就是它不支持一次更新太多的數(shù)據(jù),所以就有了 Service 層中的批量更新操作

到此這篇關(guān)于如何對(duì) Excel 表格中提取的數(shù)據(jù)進(jìn)行批量更新的文章就介紹到這了,更多相關(guān)Excel 表格數(shù)據(jù)批量更新內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Spring rest接口中的LocalDateTime日期類型轉(zhuǎn)時(shí)間戳

    Spring rest接口中的LocalDateTime日期類型轉(zhuǎn)時(shí)間戳

    這篇文章主要介紹了Spring rest接口中的LocalDateTime日期類型轉(zhuǎn)時(shí)間戳的方法,Java程序中一般將日期類型定義為L(zhǎng)ocalDateTime,數(shù)據(jù)庫(kù)中保存的時(shí)間是0時(shí)區(qū)的時(shí)間
    2023-03-03
  • Java中十六進(jìn)制和十進(jìn)制之間互相轉(zhuǎn)換代碼示例

    Java中十六進(jìn)制和十進(jìn)制之間互相轉(zhuǎn)換代碼示例

    這篇文章主要給大家介紹了關(guān)于Java中十六進(jìn)制和十進(jìn)制之間互相轉(zhuǎn)換的相關(guān)資料,我們項(xiàng)目過程中總是要用到十進(jìn)制與十六進(jìn)制相互轉(zhuǎn)換的方法,需要的朋友可以參考下
    2023-07-07
  • 關(guān)于mybatis plus 中的查詢優(yōu)化問題

    關(guān)于mybatis plus 中的查詢優(yōu)化問題

    這篇文章主要介紹了關(guān)于mybatis plus 中的查詢優(yōu)化問題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟

    SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟

    這篇文章主要介紹了SpringBoot實(shí)現(xiàn)OneDrive文件上傳的詳細(xì)步驟,文中通過代碼示例和圖文講解的非常詳細(xì),對(duì)大家實(shí)現(xiàn)OneDrive文件上傳有一定的幫助,需要的朋友可以參考下
    2024-02-02
  • Java Spring Cloud Bus 實(shí)現(xiàn)配置實(shí)時(shí)更新詳解

    Java Spring Cloud Bus 實(shí)現(xiàn)配置實(shí)時(shí)更新詳解

    這篇文章主要介紹了SpringCloud Bus如何實(shí)現(xiàn)配置刷新,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2021-09-09
  • springboot webflux 過濾器(使用RouterFunction實(shí)現(xiàn))

    springboot webflux 過濾器(使用RouterFunction實(shí)現(xiàn))

    這篇文章主要介紹了springboot webflux 過濾器(使用RouterFunction實(shí)現(xiàn)),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • JAVA代碼設(shè)置selector不同狀態(tài)下的背景顏色

    JAVA代碼設(shè)置selector不同狀態(tài)下的背景顏色

    這篇文章主要介紹了JAVA代碼設(shè)置selector不同狀態(tài)下的背景顏色,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2018-05-05
  • 使用Java模擬鼠標(biāo)和鍵盤的詳細(xì)操作步驟

    使用Java模擬鼠標(biāo)和鍵盤的詳細(xì)操作步驟

    這篇文章主要介紹了使用Java模擬鼠標(biāo)和鍵盤的詳細(xì)操作步驟,要運(yùn)行上面提供的Java程序,您需要遵循幾個(gè)步驟來設(shè)置Java環(huán)境、編寫程序代碼,并執(zhí)行該程序,文中有相關(guān)的代碼示例,需要的朋友可以參考下
    2024-05-05
  • Java設(shè)計(jì)模式之建造者模式的示例詳解

    Java設(shè)計(jì)模式之建造者模式的示例詳解

    建造者模式,是一種對(duì)象構(gòu)建模式 它可以將復(fù)雜對(duì)象的建造過程抽象出來,使這個(gè)抽象過程的不同實(shí)現(xiàn)方法可以構(gòu)造出不同表現(xiàn)的對(duì)象。本文將通過示例講解建造者模式,需要的可以參考一下
    2022-02-02
  • MyBatis增刪改查快速上手

    MyBatis增刪改查快速上手

    這篇文章給大家講解的是MyBatis 這門技術(shù)的 CURD (增刪改查) ,非常的詳細(xì)與實(shí)用,有需要的小伙伴可以參考下
    2020-02-02

最新評(píng)論