三台 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))
1
qieqie 217 天前 via iPhone
试试在每台机器上单独执行而不是远程表。当然原子性和一致性需要你手动保障。
|
2
luozic 217 天前
如果需要修改大量数据,可以先将数据导出到文件中,然后使用修改后的数据重新导入表中。
|
3
standchan 217 天前
直接修改本地表,你可能不能通过远程表去修改。
|
4
ymz 217 天前
可以修改,不过好久没用了,之前的记录在另一个电脑
|
5
anonyp 217 天前 via iPhone
ALTER TABLE databsae.table ,写的是本地表还是分布式表?看报错应该是要填本地表?
|
6
fruitmonster OP 我知道了,各位大佬,我先查远程表,然后再修改每一台的本地表,谢谢各位的解答
|
7
suixn 217 天前
alter 本地表 on cluster
|
8
kneo 217 天前 via Android
你要是需要频繁修改可能不适合用 clickhouse 。
|
9
OliverDD 216 天前
ClickHouse 修改数据不是同步的,他会启动任务在后台跑(前台等待超时后会给你提示),具体啥时候跑完全看数据量和 ClickHouse 的调度。建议一般不要做修改,对 ClickHouse 的性能影响很大
|
10
fruitmonster OP @kneo 嗯,只是写了个 Bug ,
|