V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
nekoneko
V2EX  ›  PostgreSQL

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

  •  
  •   nekoneko · 2018-11-19 18:13:21 +08:00 · 2071 次点击
    这是一个创建于 2206 天前的主题,其中的信息可能已经有所发展或是发生改变。
    • 1.数据库建了 id 和 count_time 的联合索引

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

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

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

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

    第 1 条附言  ·  2018-11-20 09:11:48 +08:00
    补充:对这些要更新的表会进行水平分表,例如 10 月的和 11 月的分成不同的表,我觉得这里可能有性能上的影响
    第 2 条附言  ·  2018-11-20 11:11:09 +08:00
    解决了...数据库中有一个 count_date 字段,建了索引,改了条件语句为 where countdate= and id= and counttime=.数据库会先根据 countdate 过滤大部分数据,效率提升了 10 多倍......
    2 条回复    2018-11-20 09:09:05 +08:00
    opengps
        1
    opengps  
       2018-11-20 08:08:39 +08:00 via Android
    为什么不直接把那个联合索引改为聚集索引?
    nekoneko
        2
    nekoneko  
    OP
       2018-11-20 09:09:05 +08:00
    @opengps 因为是两个条件语句啊,一个 id,一个 count_time
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1094 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 25ms · UTC 19:27 · PVG 03:27 · LAX 11:27 · JFK 14:27
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.