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

相关推荐
HHVic11 分钟前
普通IT的股票交易成长史--20250428晚
学习·生活
yuhouxiyang9 小时前
学习海康VisionMaster之路径提取
学习·计算机视觉
PLUS_WAVE10 小时前
CogCoM: A Visual Language Model with Chain-of-Manipulations Reasoning 学习笔记
学习·语言模型·大模型·cot·vlm·推理模型·reasoning
绵绵细雨中的乡音10 小时前
Linux进程学习【环境变量】&&进程优先级
linux·运维·学习
贺函不是涵10 小时前
【沉浸式求职学习day27】
学习
努力奋斗的小杨10 小时前
学习MySQL的第十二天
数据库·笔记·学习·mysql·navicat
枫叶200011 小时前
OceanBase数据库-学习笔记1-概论
数据库·笔记·学习·oceanbase
你可以叫我仔哥呀11 小时前
k8s学习记录(五):Pod亲和性详解
学习·容器·kubernetes
RaLi和夕12 小时前
单片机学习笔记9.数码管
汇编·笔记·单片机·嵌入式硬件·学习
见青..12 小时前
【学习笔记】文件包含漏洞--本地远程包含、伪协议、加密编码
前端·笔记·学习·web安全·文件包含