文档首页/ MapReduce服务 MRS/ 用户指南(安卡拉区域)/ 故障排除/ 使用Hive/ 增加分区列后再insert数据显示为NULL
更新时间:2024-11-29 GMT+08:00

增加分区列后再insert数据显示为NULL

问题现象

  1. 执行如下命令创建表
    create table test_table(
    col1 string,
    col2 string
    )
    PARTITIONED BY(p1 string)
    STORED AS orc tblproperties('orc.compress'='SNAPPY');
  2. 修改表结构,添加分区并插入数据
    alter table test_table add partition(p1='a');
    insert into test_table partition(p1='a') select col1,col2 from temp_table;
  3. 修改表结构,添加列并插入数据
    alter table test_table add columns(col3 string);
    insert into test_table partition(p1='a') select col1,col2,col3 from temp_table;
  4. 查询test_table表数据,返回结果中列col3的值全为NULL
    select * from test_table where p1='a' 
  5. 新添加表分区,并插入数据
    alter table test_table add partition(p1='b');
    insert into test_table partition(p1='b') select col1,col2,col3 from temp_table; 
  6. 查询test_table表数据,返回结果中列col3有不为NULL的值
    select * from test_table where p1='b'

原因分析

在alter table时默认选项为RESTRICT,RESTRICT只会更改元数据,不会修改在此操作之前创建的partition的表结构,而只会修改在此之后创建的新的partition,所以查询时旧的partition中的值全为NULL。

处理步骤

add column时加入cascade关键字即可,例如:
alter table test_table add columns(col3 string) cascade;