hive:函数:size(数组字段)获取array长度和 length(字段)获取字符串长度

获取字符串长度:length(字段)

字符串转数组:collect_list 列转行可得到数据,或split()某个字段得到数组

获取数组长度:size(数组字段)

参考sql: 

set edate=2019-07-21
SET company=***;
SET recomrecords=ods.ods_${hiveconf:company_RecomRecords;
SET employees=ods.ods_${hiveconf:company}_base_employees;
SET branchs=ods.ods_${hiveconf:company}_base_branchs;
SET regions=ods.ods_${hiveconf:company}_base_regions;

SELECT
    EmployeeNo,
    collect_list(FillinDate)                                   FillinDate,
    collect_list(FillinDate)[size(collect_list(FillinDate))-1] FillinDate,//取数组最后一个值
    size(collect_list(FillinDate))
FROM
    ${hiveconf:recomrecords}
WHERE
    EmployeeNo='401800106'
AND FillinDate>='2019-07-15'
AND FillinDate<='2019-07-21'
AND PhaseId=10
AND IsApprove=1
AND IsCancel IS NULL
GROUP BY
    EmployeeNo
ORDER BY
    fillindate DESC

 

  • 2
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值