hive学习(六)

一、函数

1.单行函数

特点:输入一行,输出一行(一进一出)

可分为日期函数,字符串函数,集合函数,数学函数和流程控制函数等

1)算术运算函数

2)数值函数

--round函数

复制代码
//四舍五入
select  round(3.5);

--ceil

复制代码
//向上取整
select  ceil(3.1);

--floor

复制代码
//向下取整
select  floor(3.1);

3)字符串函数

4)日期函数

5)条件函数

6)集合函数

7)高级聚合函数

8)炸裂函数(UDTF)

UDTF,接收一行数据,输出一行或多行数据

---explode(将一个数组炸裂成多行)

复制代码
select explode(array("老师","程序员","科学家")) as job;

----explode(将map类型集合炸裂成2列)

复制代码
select explode(map("nic","老师","marry","程序员","nim","科学家"))as (name,job);

---posexplode(将array集合的元素及其下标分成两列显示出来)

复制代码
select explode(array("老师","程序员","科学家")) as (pos,job);

---inline函数(

复制代码
select inline(array
(named_struct("id", 1, "name", "zs"),
named_struct("id", 2, "name", "Is"),
named_struct("id", 3, "name", "ww"))
) as (id, name);

扩:Lateral View:通常与UDTF配合使用。Lateral View可以将UDTF应用到源表的每行数据,将每行数据转换为一行或多行,并将源表中每行的输出结果与该行连接起来,形成一个虚拟表。

相关推荐
TL滕31 分钟前
从0开始学算法——第十五天(滑动窗口练习)
笔记·学习·算法
江苏世纪龙科技32 分钟前
开启汽车实训新维度:基于真实标准的虚拟仿真教学软件
学习
逐辰十七33 分钟前
freertos学习笔记12--个人自用-第16章 软件定时器(software timer)
笔记·学习
玩具猴_wjh43 分钟前
12.13 学习笔记
笔记·学习
雾岛听风眠43 分钟前
运放学习笔记
笔记·学习
肥大毛43 分钟前
C++入门学习---结构体
开发语言·c++·学习
likeshop 好像科技1 小时前
新手学习AI智能体Agent逻辑设计的指引
人工智能·学习·开源·github
副露のmagic1 小时前
更弱智的算法学习 day11
学习
冲,干,闯2 小时前
CH32V307以太网学习
学习
测试小张z2 小时前
软考自学两个月通过系统集成项目管理师的考试
学习·学习方法