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

相关推荐
QT 小鲜肉2 小时前
【QT/C++】Qt网络编程进阶:TCP网络编程的基本原理和实际应用(超详细)
c语言·开发语言·网络·c++·qt·学习·tcp/ip
浮游本尊2 小时前
React 18.x 学习计划 - 第六天:React路由和导航
前端·学习·react.js
yuxb733 小时前
Zabbix企业级分布式监控系统(上)
笔记·学习·zabbix
Chloeis Syntax10 小时前
MySQL初阶学习日记(1)--- 数据库的基本操作
数据库·学习·mysql
musenh11 小时前
css样式学习
css·学习·css3
Larry_Yanan12 小时前
QML学习笔记(五十)QML与C++交互:QML中单例C++对象
开发语言·c++·笔记·qt·学习·ui·交互
im_AMBER12 小时前
算法笔记 09
c语言·数据结构·c++·笔记·学习·算法·排序算法
Nan_Shu_61413 小时前
学习:JavaScript(5)
开发语言·javascript·学习
民乐团扒谱机13 小时前
实验室安全教育与管理平台学习记录(八)特种设备安全
学习·安全
喜欢吃燃面14 小时前
C++:哈希表
开发语言·c++·学习