clickhouse 删除表重建
时间: 2023-10-14 20:05:02 浏览: 318
DB2误删除表的恢复
在ClickHouse中,当我们删除一个表后重新创建同名的表时可能会遇到问题。报错提示为"Existing table metadata in ZooKeeper differs in primary key",这是因为在ZooKeeper中存在与我们要创建的表同名的表的元数据。
要解决这个问题,我们可以通过在ZooKeeper上删除相应的表来重新建表。有几种方法可以实现这个目标:
1. 使用ZooKeeper的命令行客户端zkCli.sh登录到ZooKeeper服务器。执行以下命令来删除ClickHouse表的节点:
```
./zkCli.sh -server 127.0.0.1:2181
deleteall /clickhouse/${db_name}/tables/01/${table_name}
```
这里`${db_name}`是待删除表所在的数据库名,`${table_name}`是待删除的表名。通过使用`ls /clickhouse`命令可以查看子节点。
2. 另外一种方法是修改ClickHouse的配置文件`clickhouse-server/config.xml`中的`<database_atomic_delay_before_drop_table_sec>`标签值。然而,根据引用的描述,我无法找到这个具体的配置项。
无论你选择哪种方法,通过删除ZooKeeper中的表来重新建表将解决这个问题,使你能够成功地删除表并重新创建表。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* [Clickhouse彻底删除表, drop表后重新创建报错,Code: 342, Existing table metadata in ZooKeeper differs ...](https://blog.csdn.net/qq_36724501/article/details/123830511)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
- *3* [clickhouse 删除分布式表 分本地 立马重建报错 DB::Exception: Replica /ClickHouse/tables/***/ already ...](https://blog.csdn.net/TaiYangb/article/details/129317084)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"]
[ .reference_list ]
阅读全文