
hive中在表结构中添加字段,并将字段指定到于业务库相对的位置:
alter table ods_test.ods_ppy_op_op_supplier_goods_quote_apply add columns (storage_id bigint comment '仓库id') cascade;
alter table ods_test.ods_ppy_op_op_supplier_goods_quote_apply change storage_id storage_id bigint after supplier_id;
然后 重新抽取业务库数据,select * 发现字段值错位。
因为改日期的分区之前就已经存在,而在元数据的关联关系(如第一张图)是引用的之前的表结构,所以查出来会错位。
解决:
1、直接删除表,重新建立新表,数据重新加载。简单粗暴。
2、修改mysql表的hive元数据,将分区对应的表SD_ID修改为最新的表对的id即可。
3、删除表分区,重新加分区。
alter table ods_test.ods_ppy_op_op_supplier_goods_quote_apply add partition(dateid='2021-08-31');
alter table ods_test.ods_ppy_op_op_supplier_goods_quote_apply add partition(dateid='2021-08-30');
-- 删除多个分区
--alter table ods_test.ods_ppy_finance_settle_return_goods_bill drop parti

最低0.47元/天 解锁文章
1255

被折叠的 条评论
为什么被折叠?



