首页 > 解决方案 > hive 不支持合并功能

问题描述

试图将值从表更新到另一个表,这两个表具有相同的字段名称但不同的值,查询必须在任何普通数据库上正常工作,但在这里它返回

编译语句时出错:FAILED: ParseException line 1:0 cannot identify input near 'MERGE' 'INTO' 'FINAL'

MERGE 
INTO FINAL 
USING FIRST_STAGE
ON IMSI = FIRST_STAGE.IMSI and Site = FIRST_STAGE.Site
WHEN MATCHED THEN UPDATE SET
  Min_Date = least(FIRST_STAGE.Min_Date, Min_Date),
  Max_Date = greatest(FIRST_STAGE.Max_Date, Max_Date),
  NoofDays = FIRST_STAGE.NoofDays + NoofDays,
  Down_Link = FIRST_STAGE.Down_Link + Down_Link,
  up_Link = FIRST_STAGE.up_Link + up_Link,
  connection = FIRST_STAGE.connection + connection
WHEN NOT MATCHED THEN INSERT ( Min_Date, 
  Max_Date, 
  NoofDays, 
  IMSI, 
  Site, 
  Down_Link, 
  Up_Link, 
  Connection )
VALUES ( FIRST_STAGE.Min_Date, 
  FIRST_STAGE.Max_Date, 
  FIRST_STAGE.NoofDays, 
  FIRST_STAGE.IMSI, 
  FIRST_STAGE.Site, 
  FIRST_STAGE.Down_Link, 
  FIRST_STAGE.Up_Link, 
  FIRST_STAGE.Connection )

标签: hivehiveqlcloudera-manager

解决方案


Hive合并语句Hortonworks distribution.

  • merge statement这些运行的先决条件是:

    最终表需要使用transactional enabled ,ORC format ,and bucketed.

AFAIK 如果Cloudera distribution我们需要使用Kuducloudera-5.10+.

笔记: Upsert statement only works for Impala tables that use the Kudu storage engine.

  • 我不认为我们现在可以运行CDH发行版中提到的合并语句。

推荐阅读