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

clickhouse 怎么修改数据呢?

  •  
  •   fruitmonster · 12 天前 · 950 次点击

    三台 clickhouse 集群

    因为写了个 Bug 导致数据库中的某张表的某个字段没有写入值,现在希望能刷数据,更改下,但是弄了半天都没有成功,求助各位大佬,我应该怎么做能修复这部分数据

    
    ALTER TABLE databsae.table ON CLUSTER cluster_3shards 
    UPDATE 字段 1 = '1'  
    WHERE 条件 1 = 'W1' AND 条件 2 = '' AND 条件 3 = '条件 3'
    
    

    报错如下:

    
    DB::Exception: Table engine Distributed doesn't support mutations. (NOT_IMPLEMENTED) (version 24.2.1.2248 (official build)). (NOT_IMPLEMENTED) (version 24.2.1.2248 (official build))
    
    
    10 条回复    2024-04-19 12:16:12 +08:00
    qieqie
        1
    qieqie  
       12 天前 via iPhone
    试试在每台机器上单独执行而不是远程表。当然原子性和一致性需要你手动保障。
    luozic
        2
    luozic  
       12 天前
    如果需要修改大量数据,可以先将数据导出到文件中,然后使用修改后的数据重新导入表中。
    standchan
        3
    standchan  
       12 天前
    直接修改本地表,你可能不能通过远程表去修改。
    ymz
        4
    ymz  
       12 天前
    可以修改,不过好久没用了,之前的记录在另一个电脑
    anonyp
        5
    anonyp  
       12 天前 via iPhone
    ALTER TABLE databsae.table ,写的是本地表还是分布式表?看报错应该是要填本地表?
    fruitmonster
        6
    fruitmonster  
    OP
       12 天前
    我知道了,各位大佬,我先查远程表,然后再修改每一台的本地表,谢谢各位的解答
    suixn
        7
    suixn  
       12 天前
    alter 本地表 on cluster
    kneo
        8
    kneo  
       12 天前 via Android
    你要是需要频繁修改可能不适合用 clickhouse 。
    OliverDD
        9
    OliverDD  
       11 天前
    ClickHouse 修改数据不是同步的,他会启动任务在后台跑(前台等待超时后会给你提示),具体啥时候跑完全看数据量和 ClickHouse 的调度。建议一般不要做修改,对 ClickHouse 的性能影响很大
    fruitmonster
        10
    fruitmonster  
    OP
       11 天前
    @kneo 嗯,只是写了个 Bug ,
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   我们的愿景   ·   实用小工具   ·   992 人在线   最高记录 6543   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 23:20 · PVG 07:20 · LAX 16:20 · JFK 19:20
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.