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应用到源表的每行数据,将每行数据转换为一行或多行,并将源表中每行的输出结果与该行连接起来,形成一个虚拟表。

相关推荐
立志成为大牛的小牛3 小时前
数据结构——二十三、并查集的终极优化(王道408)
开发语言·数据结构·笔记·学习·程序人生·考研
QT 小鲜肉4 小时前
【个人成长笔记】Qt Creator快捷键终极指南:从入门到精通
开发语言·c++·笔记·qt·学习·学习方法
QT 小鲜肉6 小时前
【数据结构与算法基础】05. 栈详解(C++ 实战)
开发语言·数据结构·c++·笔记·学习·算法·学习方法
A9better7 小时前
嵌入式开发学习日志40——stm32之I2C协议层
stm32·单片机·嵌入式硬件·学习
ha20428941947 小时前
Linux操作系统学习之---线程控制
java·linux·学习
Laplaces Demon9 小时前
Spring 源码学习(十四)—— HandlerMethodArgumentResolver
java·开发语言·学习
青衫码上行10 小时前
【从0开始学习Java | 第22篇】反射
java·开发语言·学习
hmbbcsm10 小时前
python学习之路(四)
学习
Greedy Alg10 小时前
Socket编程学习记录
网络·websocket·学习
知识分享小能手10 小时前
uni-app 入门学习教程,从入门到精通,uni-app 基础知识详解 (2)
前端·javascript·windows·学习·微信小程序·小程序·uni-app