已解决
hive和presto的求数组长度函数区别及注意事项
来自网友在路上 141841提问 提问时间:2023-10-22 09:24:09阅读次数: 41
最佳答案 问答题库418位专家为你答疑解惑
1、任务
获取邮箱字符串’@'后字符串 ,求长度
2、hive & spark-sql 求数组长度的函数 size
hive & spark-sql 求数组长度的函数 sizeselect size(split(email, '@')),split(email, '@'),split(email, '@')[0],split(email, '@')[1]
FROM
(select "jack@126.com" as email union select "tom@126.com.cn" as email) tb_mid;select size(split(email, '@')),split(email, '@'),split(email, '@')[0],split(email, '@')[1]
FROM
(select 'jack@126.com' as email union select 'tom@126.com.cn' as email) tb_mid;2 ["tom","126.com.cn"] tom 126.com.cn
2 ["jack","126.com"] jack 126.com
Time taken: 0.723 seconds, Fetched 2 row(s)
3、presto 求数组长度的函数 cardinality
presto 求数组长度的函数 cardinalityselect cardinality(split(email, '@')),split(email, '@'),split(email, '@')[1],split(email, '@')[2]
FROM
(select 'jack@126.com' as email union select 'tom@126.com.cn' as email) tb_mid;_col0 | _col1 | _col2 | _col3
-------+-------------------+-------+------------2 | [tom, 126.com.cn] | tom | 126.com.cn 2 | [jack, 126.com] | jack | 126.com
(2 rows)select cardinality(split(email, '@')),split(email, '@'),split(email, '@')[1],split(email, '@')[2]
FROM
(select "jack@126.com" as email union select "tom@126.com.cn" as email) tb_mid;Query 20231019_070945_20009_n9u2s failed: line 3:9: Column 'jack@126.com' cannot be resolved
select cardinality(split(email, '@')),split(email, '@'),split(email, '@')[1],split(email, '@')[2]
FROM
(select "jack@126.com" as email union select "tom@126.com.cn" as email) tb_mid
4、注意事项
1)、在计算数组长度的时候,hive和presto的函数不同
其中hive的size函数默认数组的下标从0开始
presto的cardinality函数默认数组的下标从1开始
2)、presto 不支持双引号 ,而hive 既支持单引号,也支持双引号
presto> SELECT -> email,-> (case when cardinality(split(email, '@')) = 2 then split(email, '@')[1] else '' end ) as email_suffix-> FROM -> (select "jack@126.com" as email union select "tom@126.com.cn" as email) tb_mid;
Query 20231016_070153_17958_p9f2s failed: line 5:9: Column 'jack@126.com' cannot be resolved
SELECT
email,
(case when cardinality(split(email, '@')) = 2 then split(email, '@')[1] else '' end ) as email_suffix
FROM
(select "jack@126.com" as email union select "tom@126.com.cn" as email) tb_mid
查看全文
99%的人还看了
相似问题
猜你感兴趣
版权申明
本文"hive和presto的求数组长度函数区别及注意事项":http://eshow365.cn/6-21504-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!
- 上一篇: 竞赛选题 深度学习二维码识别
- 下一篇: 缓存相关问题