Hive(七)【内置函数】
一.系统内置函数
1.查看系统自带内置函数
show functions;
2.查看函数的具体用法
如查看upper
函数
desc function extended upper;
二.常用内置函数
1.数学函数
round
round(DOUBLE a):返回对a四舍五入的BIGINT值
round(DOUBLE a, INT d):返回DOUBLE型d的保留n位小数的DOUBLE型的近似值
案例
0: jdbc:hive2://hadoop102:10000> select round(4.5),round(4.12345,2);
+------+-------+
| _c0 | _c1 |
+------+-------+
| 5 | 4.12 |
+------+-------+
2.字符函数
split
split(string str, string pat) 返回类型:array
解析:按照正则表达式pat来分割字符串str,并将分割后的数组字符串的形式返回。
案例
0: jdbc:hive2://hadoop102:10000> select split('aaa-bbb-ccc','-');
+----------------------+
| _c0 |
+----------------------+
| ["aaa","bbb","ccc"] |
+----------------------+
substring
substring(string A, int start, int len) 返回类型:string
解析:对于字符串A,从start位置开始截取长度为length的字符串并返回
案例
0: jdbc:hive2://hadoop102:10000> select substring('2020-06-29',1,7);
+----------+
| _c0 |
+----------+
| 2020-06 |
+----------+
concat
concat(string A, string B...) 返回类型:string
解析:将每个字符串拼接,也可以是sql查询的字段
案例
0: jdbc:hive2://hadoop102:10000> select concat('aaa','--','bbb','|','ccc');
+---------------+
| _c0 |
+---------------+
| aaa--bbb|ccc |
+---------------+
concat_ws
concat_ws(string SEP, string A, string B...)
解析:sep是分割符,其余字符串以这个分割符拼接
案例
0: jdbc:hive2://hadoop102:10000> select concat_ws('-','aaa','bbb','ccc');
+--------------+
| _c0 |
+--------------+
| aaa-bbb-ccc |
+--------------+
lower,upper
解析:lower将字符串转全部转为小写,upper将字符串转全部转为大写
案例
0: jdbc:hive2://hadoop102:10000> select lower('Hello World') ,upper('Hello World');
+--------------+--------------+
| _c0 | _c1 |
+--------------+--------------+
| hello world | HELLO WORLD |
+--------------+--------------+
trim
解析:去前后空格
length
解析:字符串长度,字符数
3.日期函数
to_date
解析:从一个字符串中取出为日期的部分
案例
0: jdbc:hive2://hadoop102:10000> select to_date('2020-06-29 20:34:01');
+-------------+
| _c0 |
+-------------+
| 2020-06-29 |
+-------------+
yaer、month、day
解析:从一个日期中取出相应的年、月、日
案例
0: jdbc:hive2://hadoop102:10000> select year('2020-06-29 20:34:01'),month('2020-06-29 20:34:01'),day('2020-06-29 20:34:01');
+-------+------+------+
| _c0 | _c1 | _c2 |
+-------+------+------+
| 2020 | 6 | 29 |
+-------+------+------+
4.条件函数
case...when...
语法格式:case A when B then C [when D then E]* [else F] end
解析:对于A来说,如果判断为B则返回C,如果判断为D则返回E(此处判断条件可为多个),如果以上都不是则返回F。注意,最后还有还有一个end结束符
案例
需求:求不同部门的男女各有多少人
原始数据 : emp_sex.txt
name dept_id sex
悟空 A 男
大海 A 男
宋宋 B 男
凤姐 A 女
婷姐 B 女
婷婷 B 女
建表
create table emp_sex(
name string,
dept_id string,
sex string
)
row format delimited fields terminated by '\t';
把原始数据导入表
load data local inpath '/opt/module/testdata/emp_sex.txt' into table emp_sex;
查看一下
select * from emp_sex;
name|dept_id|sex|
----|-------|---|
悟空 |A |男 |
大海 |A |男 |
宋宋 |B |男 |
凤姐 |A |女 |
婷姐 |B |女 |
婷婷 |B |女 |
实现:分组统计某个字段不同值得数量;
select
dept_id,
sum(case when sex='男' then 1 else 0 end) man_count,
sum(case when sex='女' then 1 else 0 end) woman_count
from emp_sex
group by dept_id;
nvl
语法:NVL( 字段值,value)
解析:给空字段赋值,如果字段值为空则赋值为value,否则字段值不变;若都为null那么返回null
案例
0: jdbc:hive2://hadoop102:10000> select nvl('aaa',1),nvl(null,1);
+------+------+
| _c0 | _c1 |
+------+------+
| aaa | 1 |
+------+------+
5.get_json_object函数
使用方式
get_json_object(json_txt, path): 从一个JSON字符串中取出指定路径对应的数据!
核心:path怎么写?
$: 代表根对象
. : 获取元素的属性
[] : 索引获取一个数组中子元素
案例
数据格式
[{"name":"大郎","sex":"男","age":"25"},{"name":"西门庆","sex":"男","age":"47"}]
取出第一个json对象
hive> select get_json_object('[{"name":"大郎","sex":"男","age":"25"},{"name":"西门庆","sex":"男","age":"47"}]','$[0]');
OK
{"name":"大郎","sex":"男","age":"25"}
Time taken: 0.175 seconds, Fetched: 1 row(s)
取出第一个json的age字段的值
hive> select get_json_object('[{"name":"大郎","sex":"男","age":"25"},{"name":"西门庆","sex":"男","age":"47"}]','$[0].age');
OK
25
Time taken: 0.172 seconds, Fetched: 1 row(s)
6.str_to_map
str_to_map(text, delimiter1, delimiter2)
将字符串切转化为map集合,delimiter1是每个entry分割符,delimiter2是entry的K-V分割符。
案例
将字符串'zhangsan=12,lisi=20,wangwu=30',转化为map集合。
hive (default)> select str_to_map('zhangsan=12,lisi=20,wangwu=30',',','=');
OK
_c0
{"zhangsan":"12","lisi":"20","wangwu":"30"}
Time taken: 3.248 seconds, Fetched: 1 row(s)
常用函数查询
常用日期函数
unix_timestamp:返回当前或指定时间的时间戳 select unix_timestamp(); select unix_timestamp('2008-08-08 08:08:08');
from_unixtime:将时间戳转为日期格式 select from_unixtime(1218182888);
current_date:当前日期 select current_date();
current_timestamp:当前的日期加时间 select current_timestamp();
to_date:抽取日期部分 select to_date('2008-08-08 08:08:08'); select to_date(current_timestamp());
year:获取年 select year(current_timestamp());
month:获取月 select month(current_timestamp());
day:获取日 select DAY(current_timestamp());
hour:获取时 select HOUR(current_timestamp());
minute:获取分 select minute(current_timestamp());
second:获取秒 select SECOND(current_timestamp());
weekofyear:当前时间是一年中的第几周 select weekofyear(current_timestamp()); select weekofyear('2020-01-08');
dayofmonth:当前时间是一个月中的第几天 select dayofmonth(current_timestamp()); select dayofmonth('2020-01-08');
months_between: 两个日期间的月份 select months_between('2020-07-29','2020-06-28');
add_months:日期加减月 select add_months('2020-06-28',1);
datediff:两个日期相差的天数 select datediff('2019-03-01','2019-02-01'); select datediff('2020-03-01','2020-02-01');
date_add:日期加天数 select date_add('2019-02-28',1); select date_add('2020-02-28',1);
date_sub:日期减天数 select date_sub('2019-03-01',1); select date_sub('2020-03-01',1);
last_day:日期的当月的最后一天 select last_day('2020-02-28'); select last_day('2019-02-28');
date_format() :格式化日期 日期格式:'yyyy-MM-dd hh:mm:ss' select date_format('2008-08-08 08:08:08','yyyy-MM-dd hh:mm:ss');
常用取整函数
round: 四舍五入 select round(4.5);
ceil: 向上取整 select ceil(4.5);
floor: 向下取整 select floor(4.5);
常用字符串操作函数
upper: 转大写 select upper('abcDEFg');
lower: 转小写 select lower('abcDEFg');
length: 长度 select length('abcDEFg');
trim: 前后去空格 select length(' abcDEFg '); select length(trim(' abcDEFg '));
lpad: 向左补齐,到指定长度 select lpad('abc',11,'*');
rpad: 向右补齐,到指定长度 select rpad('abc',11,'*');
substring: 剪切字符串 select substring('abcdefg',1,3); select rpad(substring('13843838438',1,3),11,'*');
regexp_replace: SELECT regexp_replace('100-200', '(\\d+)', 'num'); select regexp_replace('abc d e f',' ','');
使用正则表达式匹配目标字符串,匹配成功后替换!
集合操作
size: 集合中元素的个数
map_keys: 返回map中的key
map_values: 返回map中的value select size(friends),map_keys(children),map_values(children) from person;
array_contains: 判断array中是否包含某个元素 select array_contains(friends,'lili') from person;
sort_array: 将array中的元素排序 select sort_array(split('1,3,4,5,2,6,9',','));
select sort_array(split('a,d,g,b,c,f,e',','));
Hive(七)【内置函数】的更多相关文章
- [Hive_6] Hive 的内置函数应用
0. 说明 Hive 的内置函数的基本操作 | 时间函数 | String 函数 | 条件语句 | explode | split | substring 1. 基本操作 查看函数 show func ...
- hive的内置函数和自定义函数
一.内置函数 1.一般常用函数 .取整函数 round() 当传入第二个参数则为精度 bround() 银行家舍入法:为5时,前一位为偶则舍,奇则进. .向下取整 floor() .向上取整 ceil ...
- Hive学习之路 (九)Hive的内置函数
数学函数 Return Type Name (Signature) Description DOUBLE round(DOUBLE a) Returns the rounded BIGINT valu ...
- Hive的内置函数
定义: UDF(User-Defined-Function),用户自定义函数对数据进行处理. UDTF(User-Defined Table-Generating Functions) 用来解决 输入 ...
- hive中内置函数
查看函数的详细使用方法 desc function extended 函数名 例如: 1).desc function extended locate locate(substr, str[, pos ...
- Hive内置函数和自定义函数的使用
一.内置函数的使用 查看当前hive版本支持的所有内置函数 show function; 查看某个函数的使用方法及作用,比如查看upper函数 desc function upper; 查看upper ...
- hive学习笔记之七:内置函数
欢迎访问我的GitHub https://github.com/zq2599/blog_demos 内容:所有原创文章分类汇总及配套源码,涉及Java.Docker.Kubernetes.DevOPS ...
- [Hive - Tutorial] Built In Operators and Functions 内置操作符与内置函数
Built-in Operators Relational Operators The following operators compare the passed operands and gene ...
- [转] Hive 内置函数
原文见:https://cwiki.apache.org/confluence/display/Hive/LanguageManual+UDF 1.内置运算符1.1关系运算符 运算符 类型 说明 A ...
随机推荐
- 最小的K个数 牛客网 剑指Offer
最小的K个数 牛客网 剑指Offer 题目描述 输入n个整数,找出其中最小的K个数.例如输入4,5,1,6,2,7,3,8这8个数字,则最小的4个数字是1,2,3,4,. class Solution ...
- 第07课 OpenGL 光照和键盘(2)
下一段代码绘制贴图立方体.我只对新增的代码进行注解.如果您对没有注解的代码有疑问,回头看看第六课. int DrawGLScene(GLvoid) // 从这里开始进行所有的绘制 { glClear( ...
- Windows 2008 R2 NTP 时钟同步配置
一.配置 本地组策略 a.windows+R 或 "开始菜单" | "运行" ,打开运行窗口. 输入gpedit.msc打开本地组策略 b.在 本地组策略 ...
- netty系列之:搭建客户端使用http1.1的方式连接http2服务器
目录 简介 使用http1.1的方式处理http2 处理TLS连接 处理h2c消息 发送消息 总结 简介 对于http2协议来说,它的底层跟http1.1是完全不同的,但是为了兼容http1.1协议, ...
- 三、其他主机安装zabbix-agent加入到zabbix
一.yum (rpm)方式 1,下载安装对应的zabbix-agent的rpm包 rpm -Uvh https://repo.zabbix.com/zabbix/4.0/rhel/7/x86_64/ ...
- /etc/hosts 详解
/etc/hosts:主机名查询静态表,是ip地址与域名快速解析的文件.ip地址与主机名之间的映射,包括主机的别名. 通常将常用的域名和ip地址映射加入到hosts文件中,实现快速方便的访问. 如果没 ...
- Docker容器间网络互联原理,讲不明白算我输....
@ 目录 一.今天我们要搞明白的实验 二.前置网络知识 2.1.docker默认为我们创建的网络 2.2.怎么理解docker0网桥 2.3.什么是veth-pair技术? 三.同一个局域网中不同主机 ...
- Mac 搭建后端PHP+Go环境
准备工作 1. 安装brew命令 #很慢很慢.. ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/insta ...
- 【接口】HttpClient 处理get和post请求(二)(2019-07-14 18:41)
一.环境准备 1.导入httpClient依赖包 <dependency> <groupId>org.apache.httpcomponents</groupId> ...
- Java-基础-HashMap
1. 简介 Java8 HashMap结构(数组 + 列表 + 红黑树)如图: 基于哈希表的 Map 接口的实现.此实现提供所有可选的映射操作,并允许使用 null 值和 null 键.(除了非同步和 ...