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

Java使用easyExcel實(shí)現(xiàn)導(dǎo)入功能

 更新時(shí)間:2022年10月22日 09:38:33   作者:tianClassmate  
這篇文章介紹了Java使用easyExcel實(shí)現(xiàn)導(dǎo)入功能的方法,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

今天帶來的是esayExcel的簡(jiǎn)單使用小結(jié),一個(gè)高效的Excel的處理框架

臨時(shí)接到領(lǐng)導(dǎo)要求需要做一個(gè)Excel導(dǎo)入功能,于是發(fā)揮我的特長(zhǎng)——面向百度編程。

在百度搜索了一圈都是POi導(dǎo)入方式,找到一個(gè)看著還算靠譜的demo,這種方式在我看來相當(dāng)?shù)谋恐?,讀取到Excel內(nèi)容后逐個(gè)進(jìn)行判斷。折騰了一個(gè)上午,代碼像是一個(gè)年邁的老人-巋然不動(dòng),為我的菜感到汗顏。

經(jīng)過公司經(jīng)驗(yàn)豐富的老人的指導(dǎo),使用阿里巴巴開源的easyExcel導(dǎo)入方式使用很便捷,更重要的是快,十分鐘就完成了整個(gè)導(dǎo)入過程的開發(fā)。

書歸正傳,正式進(jìn)入easyExcel的使用過程。

一、導(dǎo)入依賴

<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>easyexcel</artifactId>
  <version>2.1.1</version>
</dependency>

二、編寫entity類

public class MedicineBasicImport implements Serializable {

    /**
     * 藥品編碼
     */
    @ExcelProperty("藥品編碼")
    private String code;
    /**
     * 藥品類型
     */
    @ExcelProperty( "藥品類型")
    private String type;
     /**
     * 藥品名稱
     */
    @ExcelProperty("藥品名稱")
    private String title;

}

特別指出的是,實(shí)體屬性上需要增加 @ExcelProperty注解與Excel的表頭對(duì)應(yīng)。

三、寫操作

 @Override
    public int importBasicMedicine(MultipartFile file, Long updateSupport) {
        try {
            BufferedInputStream bufferedInputStream=new BufferedInputStream(file.getInputStream());
            EasyExcel.read(bufferedInputStream, MedicineBasicImport.class,new ImportMedicineService(updateSupport,medicineBasicMapper))
                .sheet()
                .doRead();;
        } catch (IOException e) {
            e.printStackTrace();
        }
        return 0;
    }

調(diào)用 EasyExcel.read()方法,需要傳遞三個(gè)參數(shù),1、文件流 2、實(shí)體類 3、new ImportMedicineService(updateSupport,medicineBasicMapper)處理的業(yè)務(wù)類

四、業(yè)務(wù)實(shí)現(xiàn)

ImportMedicineService需要我們繼承 AnalysisEventListener類 并實(shí)現(xiàn)它的兩個(gè)方法,invoke()和doAfterAllAnalysed()方法。

public class ImportMedicineService extends AnalysisEventListener<MedicineBasicImport> {
    private Long topDeptId;
    private TMedicineBasicMapper medicineBasicMapper;

    List<TMedicineBasic> list =  new ArrayList<>();

    public ImportMedicineService(Long updateSupport, TMedicineBasicMapper medicineBasicMapper) {
        topDeptId=updateSupport;
        this.medicineBasicMapper=medicineBasicMapper;
    }

    // 每讀取一行就調(diào)用該方法
    @Override
    public void invoke(MedicineBasicImport data, AnalysisContext context) {

        TMedicineBasic tMedicineBasic=new TMedicineBasic();
        tMedicineBasic.setId(IdUtils.simpleUUID());
        tMedicineBasic.setTopDeptId(topDeptId);
        BeanUtils.copyProperties(data,tMedicineBasic);
        list.add(tMedicineBasic);
    }

    // 全部讀取完成就調(diào)用該方法
    @Override
    public void doAfterAllAnalysed(AnalysisContext context) {
        medicineBasicMapper.insertList(list);
    }

當(dāng)我們調(diào)用導(dǎo)入接口時(shí)會(huì)調(diào)用到 AnalysisEventListener 的實(shí)現(xiàn)類的invoke()方法,但是每讀取一行都會(huì)執(zhí)行invoke()方法,大部分業(yè)務(wù)場(chǎng)景都會(huì)把讀取的內(nèi)容存入到數(shù)據(jù)庫(kù)中,如果讀取一行就保存到數(shù)據(jù)庫(kù),這對(duì)于數(shù)據(jù)庫(kù)來說簡(jiǎn)直是一個(gè)災(zāi)難。

比較好的方式就是在doAfterAllAnalysed()方法中執(zhí)行數(shù)據(jù)庫(kù)的操作,將多次數(shù)據(jù)庫(kù)IO轉(zhuǎn)為一次IO。

這種方式是不是比PIO要簡(jiǎn)單一些呢?

以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,謝謝大家對(duì)腳本之家的支持。如果你想了解更多相關(guān)內(nèi)容請(qǐng)查看下面相關(guān)鏈接

相關(guān)文章

  • 利用Spring?boot+LogBack+MDC實(shí)現(xiàn)鏈路追蹤

    利用Spring?boot+LogBack+MDC實(shí)現(xiàn)鏈路追蹤

    這篇文章主要介紹了利用Spring?boot+LogBack+MDC實(shí)現(xiàn)鏈路追蹤,MDC?可以看成是一個(gè)與當(dāng)前線程綁定的哈希表,可以往其中添加鍵值對(duì),下文詳細(xì)介紹需要的小伙伴可以參考一下
    2022-04-04
  • Mybatis-plus如何更新Null字段詳解

    Mybatis-plus如何更新Null字段詳解

    MyBatis-plus在進(jìn)行更新操作時(shí)不會(huì)更新傳入實(shí)體中為null或默認(rèn)值屬性字段,只更新不為null的值、非默認(rèn)值的屬性字段,這篇文章主要給大家介紹了關(guān)于Mybatis-plus如何更新Null字段的相關(guān)資料,需要的朋友可以參考下
    2023-07-07
  • Java透明窗體的設(shè)置方法

    Java透明窗體的設(shè)置方法

    在本文中我們給大家整理了關(guān)于Java透明窗體的設(shè)置方法以及需要注意的地方,需要的朋友們學(xué)習(xí)參考下。
    2019-03-03
  • SpringCloudConfig之client端報(bào)錯(cuò)Could?not?resolve?placeholder問題

    SpringCloudConfig之client端報(bào)錯(cuò)Could?not?resolve?placeholder問

    這篇文章主要介紹了SpringCloudConfig之client端報(bào)錯(cuò)Could?not?resolve?placeholder?‘from‘?in?value?“${from}“問題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助
    2022-12-12
  • 海量數(shù)據(jù)去重排序bitmap(位圖法)在java中實(shí)現(xiàn)的兩種方法

    海量數(shù)據(jù)去重排序bitmap(位圖法)在java中實(shí)現(xiàn)的兩種方法

    今天小編就為大家分享一篇關(guān)于海量數(shù)據(jù)去重排序bitmap(位圖法)在java中實(shí)現(xiàn)的兩種方法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2019-02-02
  • RabbitMQ消息隊(duì)列中的Channel信道參數(shù)詳解

    RabbitMQ消息隊(duì)列中的Channel信道參數(shù)詳解

    這篇文章主要介紹了RabbitMQ消息隊(duì)列中的Channel信道參數(shù)詳解,信道是生產(chǎn)消費(fèi)者與rabbit通信的渠道,生產(chǎn)者publish或者消費(fèi)者消費(fèi)一個(gè)隊(duì)列都是需要通過信道來通信的,信道是建立在TCP上面的虛擬鏈接,需要的朋友可以參考下
    2023-08-08
  • Java使用sftp定時(shí)下載文件的示例代碼

    Java使用sftp定時(shí)下載文件的示例代碼

    SFTP 為 SSH的其中一部分,是一種傳輸檔案至 Blogger 伺服器的安全方式。接下來通過本文給大家介紹了Java使用sftp定時(shí)下載文件的示例代碼,感興趣的朋友跟隨腳本之家小編一起看看吧
    2018-05-05
  • 細(xì)品Java8中hashCode方法的使用

    細(xì)品Java8中hashCode方法的使用

    這篇文章主要介紹了細(xì)品Java8中hashCode方法的使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • java中volatile關(guān)鍵字的作用與實(shí)例代碼

    java中volatile關(guān)鍵字的作用與實(shí)例代碼

    這篇文章主要給大家介紹了關(guān)于java中volatile關(guān)鍵字的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • springboot2.x 接入阿里云市場(chǎng)短信發(fā)送的實(shí)現(xiàn)

    springboot2.x 接入阿里云市場(chǎng)短信發(fā)送的實(shí)現(xiàn)

    本文主要介紹了springboot2.x 接入阿里云市場(chǎng)短信發(fā)送的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-11-11

最新評(píng)論