• 请不要在回答技术问题时复制粘贴 AI 生成的内容
rqxiao
V2EX  ›  程序员

Java 后端 做 excel 导入数据用开新线程的办法提高导入速度 是否有效

  •  
  •   rqxiao · Dec 16, 2019 · 3321 views
    This topic created in 2339 days ago, the information mentioned may be changed or developed.

    excel 假如有一百万条数据

    代码中写一段 记录条数达到 2000 条时,

    来一句 new Thread() {........}.start();

    是否可行

    8 replies    2019-12-16 19:11:23 +08:00
    dekuofa
        1
    dekuofa  
       Dec 16, 2019
    ForkJoinPool?
    chendy
        2
    chendy  
       Dec 16, 2019
    个人观点:
    做好分批批量插入就差不多了
    多线程感觉不是很划算,可能需要处理”某个线程插入失败“之类的情况,线程太多对数据库的压力也可能会比较大
    以及需要多线程的场景要用线程池不要 new Thread…
    0NF09LJPS51k57uH
        3
    0NF09LJPS51k57uH  
       Dec 16, 2019
    读的话,如果所有数据都在一个文件里面,效果应该不明显吧。
    AweGod
        4
    AweGod  
       Dec 16, 2019
    可以 1 个线程专门读取 excel 数据,再开多个线程用于写数据
    soulzz
        5
    soulzz  
       Dec 16, 2019
    保证正确性时多线程写单个文件反而更慢
    Asice
        6
    Asice  
       Dec 16, 2019
    性能明显在写,多线程写
    rumingruyue
        7
    rumingruyue  
       Dec 16, 2019
    可以用多线程,但是建议用线程池而不是手动创建线程,核心线程数和可用 CPU 数一致或者少一两个。
    另外可以了解下 completablefuture
    gaius
        8
    gaius  
       Dec 16, 2019
    取决于你用的框架
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   1033 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 42ms · UTC 18:33 · PVG 02:33 · LAX 11:33 · JFK 14:33
    ♥ Do have faith in what you're doing.