百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

技术分享:hive常用内部函数 hive常用内置函数

wptr33 2024-11-11 16:09 37 浏览

hive常用内部函数

hive是一种典型的数据仓库分析工具,常用语编写hql语句进行指标分析。在编写hql的过程中无疑会用到很多的函数,哪本章来编写一些常见的函数。常见函数很多,不同常见不同人员,使用不一样,不喜勿喷。


1、随机函数rand()

格式:rand([int seed])
返回:double
?
-- 取0-1的随机值
select rand();
-- 指定随机函数的种子seed,该随机会返回一个固定值
select rand(100);

2、切分函数split()

格式:split(str,spliter)
返回:array
?
-- 获取随机数*100,然后再取整。小数点.需要转义
select split(rand()*100,'\\.')[0];

3、字符串截取函数substring() 或 substr()

格式:substring(str,start,length)      substr(str,start,length)
返回:string
?
-- 获取随机数*100,然后再从0位置开始,取2位字符串。
select substring(rand()*100,0,2);
?
-- 获取随机数*100,然后再从0位置开始,取2位字符串。
select substr(rand()*100,0,2);

4、判断函数if()

格式:if(condition,true,false)
返回:true或者flase部分的值
?
-- 查询s_tmp表,如果s.sex等于1,则是男,否则是女
select
s.id,
s.name,
if(s.sex = 1,'男','女')
from s_tmp s
;
?
-- if嵌套查询
select
s.id,
s.name,
if(s.id = 1,'男',if(s.id = 2,'女','妖'))
from s_tmp s
;


5、选择函数case when

类似于java中的swith。比if函数更加的具有扩展性。
格式:
case 值
when 1 then ''
...
else
end
?
返回:then或者else后的值
?
格式2:
case
when 值=1 then ''
...
else
end
?
返回:then或者else后的值
?
?
-- 查询s_tmp中的s.sex,如果为1,则是男,为2则是女,其它为妖
select
s.id,
s.name,
case s.sex
when 1 then '男'
when 2 then '女'
else '妖'
end
from s_tmp s
;
?
-- 查询s_tmp中的s.sex,如果为1,则是男,为2则是女,其它为妖
select
s.id,
s.name,
case
when s.sex=1 then '男'
when s.sex=2 then '女'
else '妖'
end
from s_tmp s
;

6、正在替换函数regexp_replace()

格式:regexp_replace(str,old_string,new_str)   #old_string支持通配符
返回:string
?
-- 将.png替换为.jpg
select regexp_replace('1.png','.png','.jpg');
?
-- 将s.name的名字为zhangsan的替换为lisi
select
s.id,
regexp_replace(s.name,'zhangsan','lisi')
from s_tmp s
;

7、类型转换 函数cast()

格式: cast(x as type)
返回:type类型
?
-- 将1.0转换成int类型
select cast(1.0 as int);
?
-- 将随机数*100,转换成int类型
select cast(rand()*100 as int);

8、四舍五入函数round()

格式:round(double,保留位数)
返回:double
?
-- 随机数*100,然后四舍五入取值。没有保留位数默认四舍五入取整,比如0.0 或者 1.0
select round(rand()*100);
?
-- 随机数*100,然后保留两位小数,四舍五入取值
select round(rand()*100,2);

9、连接函数concat() 或者 concat_ws()

格式:concat(str1,str2...) 或者 concat_ws(split_str,str1,str2....)
返回:string
?
-- 将字符串1,2拼接起来
select concat("1","2");
?
-- 将字符串1,2拼接起来,并使用|来进行分割
select concat_ws("|","1","3","2");
?
-- 将id,name,sex使用|进行拼接
select
concat_ws('|',cast(s.id as string),s.name,cast(s.sex as string))
from s_tmp s
;

10、字符串长度函数length()

格式:length(str) 
返回:int
?
-- 获取name的长度
select
length(s.name)
from s_tmp s
;

相关推荐

HIVE 窗口函数详解(hive常用开窗函数)

什么是窗口函数窗口函数是SQL中一类特别的函数。和聚合函数相似,窗口函数的输入也是多行记录。不同的是,聚合函数的作用于由GROUPBY子句聚合的组,而窗口函数则作用于一个窗口,这里,窗口...

SQL高效使用20招:数据分析师必备技巧

基础优化技巧善用EXPLAIN分析执行计划EXPLAINSELECT*FROMordersWHEREorder_date>'2024-01-01';...

答记者问之 - Redis 的高效架构与应用模式解析

问:极客程序员你好,请帮我讲一讲redis答:redis主要涉及以下核心,我来一一揭幕Redis的高效架构与应用模式解析...

MySQL通过累计求新增(mysql新增表字段语句)

前两天的那篇内容《MySQL递归实现单列分列成多行》...

一文讲懂SQL窗口函数 大厂必考知识点

大家好,我是宁一。今天是我们的第24课:窗口函数。...

圣诞快乐:用GaussDB T 绘制一颗圣诞树,兼论高斯数据库语法兼容

转眼就是圣诞的节日,祝大家节日快乐。用GaussDBT(也就是GaussDB100)绘制一棵圣诞树,纯国产,更喜庆。话不多说,上图:SQL如下:SELECTCASEWHENENMOTE...

Minitab:功能强大的质量管理、统计分析及统计图形软件

一、Minitab简介Minitab软件是为质量改善、教育和研究应用领域提供统计软件和服务的先导,是全球领先的质量管理和六西格玛实施软件工具及持续质量改进的良好工具软件,她具有强大的功能和简易的可视化...

如何熟练使用SQL查询(如何熟练使用sql查询内容)

要熟练使用SQL查询(StructuredQueryLanguage),你需要系统地从语法入门,到实战练习,再到性能优化与多表查询的掌握。下面是一条循序渐进、实战驱动的学习路径:第一阶段:S...

SAP SE38如何在多个系统间同步代码

上一篇文章写了如何在多个系统之间同步开发对象:多套SAPERP之间一键同步ABAP开发内容,有兄弟问有没有简单办法同步SE38程序代码的,因为使用请求的方式同步代码有点小题大做了。...

Python | 垂直模态分解(phython垂直输出)

...

技术栈:刷了百道SQL题,还是不会用?你应该这样补短板

这是来自用户的提问,也是很多人遇到的困惑:...

mysql窗口函数为了解决更加复杂的问题

为了解决复杂问题的窗口函数我们先讲一下窗口函数是什么窗口和普通的函数作用相同在不同列上进行查询和返回比如我们有如下的表...

MariaDB开窗函数(开窗函数 mysql)

在使用GROUPBY子句时,总是需要将筛选的所有数据进行分组操作,它的分组作用域是整张表。分组以后,为每个组只返回一行。而使用基于窗口的操作,类似于分组,但却可以对这些"组"(即窗口...

一文掌握 DuckDB 时间序列分析:窗口函数实战详解

...

一篇文章搞定MySQL中的窗口函数(mysql常用的窗口函数)

我是孙斌,北理数学系毕业,分享数据分析相关知识,点击右上角“关注”,学习更多数据分析知识。在MySQL中,分组groupby一般和聚合函数连用,如groupby+sum,这样能够得到每个组的总和,...