咨询一下大家 activiti 几百万数据查询慢怎么办 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
cannotfindobject
V2EX    Java

咨询一下大家 activiti 几百万数据查询慢怎么办

  •  
  •   cannotfindobject Jul 21, 2022 3516 views
    This topic created in 1378 days ago, the information mentioned may be changed or developed.

    如题

    • 目前遇到的情况是ACT_HI_ACTINST这个表里有七百万条的数据。

    • 每次根据ASSIGNEE_查询历史流程都需要很长时间

    • activiti 为这个表设计的索引字段并没有包含ASSIGNEE_

    • ID_主键还是 varchar 类型

    • 这种情况我可以给ASSIGNEE_添加索引吗?

    • 或者有什么性价比高的方案

    16 replies    2022-07-22 11:25:37 +08:00
    tomczhen
        1
    tomczhen  
       Jul 21, 2022 via Android
    性价比高的方案:找篇 mysql 数据库查询执行计划分析的文章看看。
    bootvue
        2
    bootvue  
       Jul 21, 2022
    硬删除 long long ago history & 关联数据
    cannotfindobject
        3
    cannotfindobject  
    OP
       Jul 21, 2022
    @tomczhen 每次查询 type 都是 all ,不知道如何保全数据和业务逻辑的情况下如何进行下一步优化
    cannotfindobject
        4
    cannotfindobject  
    OP
       Jul 21, 2022
    @bootvue 旧数据也要留着:)
    wxf666
        5
    wxf666  
       Jul 21, 2022
    为何不先加 ASSIGNEE_索引试试呢?
    wolfie
        6
    wolfie  
       Jul 21, 2022
    可以建索引。
    根据 ASSIGNEE_ 查询的为什么不是 ACT_HI_TASKINST
    JohnYehyo
        7
    JohnYehyo  
       Jul 21, 2022
    前端页面无非展示三类数据:待办、在办、已办结
    可能业务特点吧,我们的表里不会有很多的在办理的流程, 但是历史记录很多
    所以 以前用 activiti 的一个笨办法:
    前两种直接用的 TaskQuery 对象查
    最后的办结直接查的业务表而非 activiti 的历史表
    potatowish
        8
    potatowish  
       Jul 21, 2022 via iPhone
    加索引试试,然后查询历史记录尽可能用自己的业务表,activiti 的历史记录表隔一段时间清理一次指定时间之前的数据。
    cannotfindobject
        9
    cannotfindobject  
    OP
       Jul 21, 2022
    @wolfie 700w 建立索引在生产环境会有什么影响吗
    wolfie
        10
    wolfie  
       Jul 21, 2022
    @cannotfindobject
    建立索引时候卡顿 10 来秒吧,700w 不算大数据量。
    可以建立个 copy 表试一下。
    QBS
        11
    QBS  
       Jul 22, 2022
    前面大佬已经说了,无非:待办、在办、已办结。我当时的处理就是将已办结的流程信息保存在自己的业务表中,我们使用的 mongodb ,因为这部分信息基本不会再发生改变了。而一般来说待办、在办这部分的流程应该相对都是比较少的。
    Belmode
        12
    Belmode  
       Jul 22, 2022
    @QBS 对的,冷热分离。
    alen0206
        13
    alen0206  
       Jul 22, 2022
    activiti 自带的表是可以建索引的
    cannotfindobject
        14
    cannotfindobject  
    OP
       Jul 22, 2022
    @Belmode 现在打算把已办结的数据都打到 es 里。
    cannotfindobject
        15
    cannotfindobject  
    OP
       Jul 22, 2022
    @alen0206 主要担心会不会对流程产生其他影响,比如插入效率之类的
    cannotfindobject
        16
    cannotfindobject  
    OP
       Jul 22, 2022
    @QBS 谢谢大佬,确实是前期设计的时候欠考虑了
    About     Help     Advertise     Blog     API     FAQ     Solana     1079 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 58ms UTC 18:40 PVG 02:40 LAX 11:40 JFK 14:40
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86