更新时间:2024-07-01 GMT+08:00
插入或更新数据时报错,提示分布键不能被更新
问题现象
往数据库插入或更新数据时报错,提示分布键不能被更新,错误信息如下所示:
1
|
ERROR: Distributed key column can't be updated in current version |
原因分析
GaussDB(DWS)分布键不允许被更新。
处理方法
方法一:分布键目前暂不支持更新,直接跳过该报错。
方法二:将分布列修改为一个不会更新的列(8.1.0版本后,支持调整分布列,以下为示例)。
- 查询当前表定义,返回结果显示该表分布列为c_last_name。
1
SELECT pg_get_tabledef('customer_t1');
- 更新分布列中的数据时报错。
1
UPDATE customer_t1 SET c_last_name = 'Jimy' WHERE c_customer_sk = 6885;
- 将该表的分布列修改为不会更新的列,例如c_customer_sk。
1
ALTER TABLE customer_t1 DISTRIBUTE BY hash (c_customer_sk);
- 重新执行更新旧的分布列的数据。更新成功。
1
UPDATE customer_t1 SET c_last_name = 'Jimy' WHERE c_customer_sk = 6885;
父主题: 数据库使用