三.表的别名
SELECT * FROM
(SELECT * FROM A)
GROUP BY COL_1
当需要类似的子查询语句时,迁移至HIVE时需要给子查询起别名,否则会报语法错误。
迁移至HIVE语句为:
SELECT * FROM
(SELECT * FROM A) B
GROUP BY B.COL_1
四.HIVE特性
在迁移的时候,会遇到一些HIVE的特性导致无法顺利迁移,如下ORACLE语句:
SELECT *
FROM A
GROUP BY A.COL_1
HAVING COUNT(DISTINCT A.COL_2) = 2
在HIVE中运行会遇到如下报错:
FAILED: SemanticException [Error 10002]: Line 19:22 Invalid column reference 'COL_2'
去掉DISTINCT后可以正常执行。
属于HIVE的特性导致的问题,HAVING子句中无法使用DISTINCT关键字,在迁移中需要进行取舍。
五.报错
1.迁移后字段数据类型有误,需要修改数据类型。
FAILED: SemanticException [Error 10016]: Line 28:5 Argument type mismatch 'COL_1': The expression after ELSE should have the same type as those after THEN: "int" is expected but "double" is found
2.
org.apache.Hadoop.hive.ql.parse.SemanticException: Big Table Alias is null
关联时主表数据为空,需要插入数据再进行测试。