UDTF是什么:
- 表生成UDF,接收一个数据行,然后返回多个数据行(一个表作为输出)。
UDTF函数语法:- 只允许单独、使用一个UDTF进行操作。
eg:select explode(array('A','B','C'));
输出:
A
B
C - 错误示例:
eg:select col1, explode(array('a','b','c'));
eg:select explode(array('a','b','c')),explode(array('A','B','C'));
原因:UDTF函数的输入是一个表结构,我们没法用一个单一字段与一个表进行拼接;也不可能将两张表直接拼接在一起。
- 只允许单独、使用一个UDTF进行操作。
一般情况下lateral view与UDTF函数一起使用
- lateral view语法:
LATERAL VIEW udtf(expression) tableAlias AS columnAlias (‘,’ columnAlias)* - eg:
select col1,newtable.clo2 from table lateral view explode(array('A','B')) newtable as clo2;
注释:
table——原表
col1——原表中的字段
newtable——explode()函数返回的表的别名
col2——新表中的字段名(newtable中的列名)
本文详细介绍了UDTF(表生成UDF)的概念及使用方法,解释了如何通过UDTF将一行数据转换为多行数据,同时展示了Lateral View语法在处理UDTF输出时的应用。通过具体示例,读者可以了解到UDTF的限制及其与Lateral View结合使用的正确方式。
3万+

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



