nekoneko
18.39D

一个关于 sql 批量更新的问题

  •  
  •   nekoneko · Nov 19, 2018 · 2559 views
    This topic created in 2761 days ago, the information mentioned may be changed or developed.
    • 1.数据库建了 id 和 count_time 的联合索引

    • 2.更新语句的条件部分是 where id= and count_time= 来更新的,更新的字段有一个建立了非聚集索引

    • 3.涉及到 id 和 time 的表大概就几百万条数据,3 张表.

    • 4.可能会有同时操作数据库的情况,但是不必担心锁的问题.

    • 然后,300 条数据花了三十秒才更新完,求救.....

    Supplement 1  ·  Nov 20, 2018
    补充:对这些要更新的表会进行水平分表,例如 10 月的和 11 月的分成不同的表,我觉得这里可能有性能上的影响
    Supplement 2  ·  Nov 20, 2018
    解决了...数据库中有一个 count_date 字段,建了索引,改了条件语句为 where countdate= and id= and counttime=.数据库会先根据 countdate 过滤大部分数据,效率提升了 10 多倍......
    2 replies    2018-11-20 09:09:05 +08:00
    opengps
        1
    opengps  
       Nov 20, 2018 via Android
    为什么不直接把那个联合索引改为聚集索引?
    nekoneko
        2
    nekoneko  
    OP
       Nov 20, 2018
    @opengps 因为是两个条件语句啊,一个 id,一个 count_time
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   942 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 21:26 · PVG 05:26 · LAX 14:26 · JFK 17:26
    ♥ Do have faith in what you're doing.