Hadoop 如何在配置单元中添加具有静态值的动态列

Hadoop 如何在配置单元中添加具有静态值的动态列,hadoop,hive,bigdata,hiveql,Hadoop,Hive,Bigdata,Hiveql,我的表格结构如下: 0: jdbc:hive2://vw118287.ds.dev.accenture.com> desc sample2; Getting log thread is interrupted, since query is done! +-------------+------------+----------+--+ | col_name | data_type | comment | +-------------+------------+---------

我的表格结构如下:

0: jdbc:hive2://vw118287.ds.dev.accenture.com> desc sample2;
Getting log thread is interrupted, since query is done!
+-------------+------------+----------+--+
|  col_name   | data_type  | comment  |
+-------------+------------+----------+--+
| event_text  | string     |          |
| load_date   | string     |          |
+-------------+------------+----------+--+  
现在,我想在向该表中插入数据时添加一个具有常量值的新列,因此我运行了以下查询:

insert into table sample2 select event_text,'2019','Sample' as SampleColumn from ccs_service_optimization_9401.so_wireless_radius_summary ;
它抛出以下错误:

Caused by: org.apache.hadoop.hive.ql.parse.SemanticException: Line 1:18 Cannot insert into target table because column number/types are different 'sample2': Table insclause-0 has 2 columns, but query has 3 columns. 

我读了很多帖子,认为这在蜂巢里是不可能的,但我相信一定有某种方式。有人对此有任何想法吗???

这在蜂巢中是不可能的。表DDL不是动态的,DML查询不影响表定义

如果要添加列,请在插入前执行

ALTER TABLE tablename ADD columns SampleColumn  string; 

此外,如果该表是,您可以删除并使用附加列创建它,旧数据将保留,新列(如果是最后一列)对于旧数据将为null

Hive version>2.0
它支持在插入脚本中指定列名称

insert into table sample2 (col_name, data_type, comment ) select event_text,'2019','Sample' as SampleColumn from ccs_service_optimization_9401.so_wireless_radius_summary;

如果您的表已分区,则不支持列规范,您可能需要在插入期间指定分区列。

谢谢@leftjoin。我已经知道这一点,但它仍然不能回答我的问题。有没有可能??有什么方法可以使这个表成为动态的吗?@RushHour您可以使用其他一些工具(比如shell)生成drop/create语句,并在Hive中执行它们。但不幸的是,不可能直接在蜂箱中进行。如果您需要使用其他工具来解决问题,那么您的问题就太广泛了。更具体地说,展示您的尝试,这将有助于更好地理解您的问题。不,谢谢,我只是想了解它是否可以直接在配置单元中实现。一种方法是将具有常量值的列作为分区列,然后将数据插入到分区中