Hive进阶(上)
Hive进阶(上)
Hive进阶(上)
执行数据导入
使用Load语句
语法:
1.LOAD DATA [LOCAL] INPATH 'filepath' [OVERWRITE] INTO TABLE tablename [PARTITION (partcol1=val1,partcol2=val2 ...)]
说明:
[LOCAL]:从操作系统中的一个目录中进行导入,如果不写LOCAL则为hdfs的数据导入
INPATH:为导入的路径,后面指明文件目录路径,如不指明文件名,则将目录下的所有文件进行导入
[OVERWRITE]:是否要覆盖表中已经存在的数据
INTO TABLE:后面跟表名,如果导入的是个分区表,还可以通过PARTITION指明导入到哪个分区当中
数据查询排序
语法:
1.SELECT [ALL | DISTINCT] select_expr,select_expr,...
2.FROM table_reference
3.[WHERE where_condition]
4.[GROUP BY col_list]
5.[CLUSTER BY col_list
6. |[DISTRIBUTE BY col_list][SORT BY col_list]
7. |[ORDER BY col_list]]
8.[LIMIT number]
DISTRIBUTE BY:指定分发器(Partitioner),多Reducer可用
使用where执行过滤
使用order by执行排序,要降序操作只需要在后面加上desc,若想在查询的时候使用列序号,可以执行set hive.groupby.orderby.position.alias=true;
简单查询的Fetch Task功能
在此状态下就不会开启Map Reduce作业,从Hive0.10.0版本开始支持
配置方式:
set hive.fetch.task.conversion=more;hive --hiveconf hive.fectch.task.conversion=more- 修改hive-site.xml文件(永久生效)
Hive的内置函数
数学函数
1.--四舍五入
2.select round(45.926,2),round(45.926,1),round(45.926,0),round(45.926,-1),round(45.926,-2);
执行结果:
1.45.93 45.9 46.0 50.0 0.0
1.--向上取整
2.select ceil(45.926);
执行结果:
1.46
1.--向下取整
2.select floor(45.926);
执行结果:
1.45
字符函数
大小写:
1.select lower('Hello World'),upper('Hello World');
执行结果:
1.hello world HELLO WORLD
字符数:
1.select length('Hello World'),length('你好');
执行结果:
1.11 2
拼加字符串:
1.select concat('Hello',' World')
执行结果:
1.Hello World
求子串:
substr(a,b):从a中,第b位开始取,取右边所有的字符
1.select substr('Hello World',3);
执行结果:
1.llo World
substr(a,b,c):从a中,第b位开始取,取c个字符
1.select substr('Hello World',3,4);
执行结果:
1.llo
去掉前后的空格:trim()
左填充:lpad()
右填充:rpad()
1.select lpad('abcd',10,'*'),rpad('abcd',10,'*');
执行结果:
1.******abcd abcd******
收集函数和转换函数
- 收集函数size()
1.select size(map(<key,value>,<key,value>...))
- 转换函数cast()
1.select cast(1 as float);
日期函数
- to_date :取出一个字符串中日期的部分
- year :取出一个日期中的年
- month :取出一个日期中的月
- day :取出一个日期的日
- weekofyear :返回一年中的第几周
- datediff :两个日期之间的相隔天数
- date_add :日期之上加上几天
- data_sub :日期之上减去几天
条件函数
coalesce:从左到右返回第一个不为null的值case...when...:条件表达式
1.CASE a WHEN b THEN c [WHEN d THEN e]*[ELSE f] END
例如:
1.给员工涨工资,总裁1000,经理800,其他400
2.
3.select ename,job.sal,
4. case job when 'PRESIDENT' then sal+1000
5. when 'MANAGER' then sal+800
6. else sal+400
7. end
8.from emp;
当然上面写法是为了好看,在hive把换行符去掉即可
聚合函数和表生成函数
- 聚合函数
- count:求个数
- sum:求和
- min:求最小值
- max:求最大值
- avg:求平均
- 表生成函数
- explode
例如:
- explode
1.select explode(map(1,'Tom',2,'Mary',3,'Mike'));
执行:
1.1 Tom
2.2 Mary
3.3 Mike
Hive进阶(上)的更多相关文章
- Hive进阶(下)
Hive进阶(下) Hive进阶(下) Hive的表连接 等值连接 查询员工信息:员工号.姓名.月薪.部门名称 1.select e.empno,e.ename,e.sal,d.dname2.from ...
- Docker入门与进阶(上)
Docker入门与进阶(上) 作者 刘畅 时间 2020-10-17 目录 1 Docker核心概述与安装 1 1.1 为什么要用容器 1 1.2 docker是什么 1 1.3 docker设计目标 ...
- Spark入门实战系列--5.Hive(上)--Hive介绍及部署
[注]该系列文章以及使用到安装包/测试数据 可以在<倾情大奉送--Spark入门实战系列>获取 .Hive介绍 1.1 Hive介绍 月开源的一个数据仓库框架,提供了类似于SQL语法的HQ ...
- Hive学习之六 《Hive进阶— —hive jdbc》 详解
接Hive学习五 http://www.cnblogs.com/invban/p/5331159.html 一.配置环境变量 hive jdbc的开发,在开发环境中,配置Java环境变量 修改/etc ...
- Hive学习之五 《Hive进阶—UDF操作案例》 详解
hive—UDF操作 udf的操作过程: 在HIVE会话中add 自定义函数的jar文件,然后创建function,继而使用函数. 下面就以下面课题为例: 课题:统计每个活动的PV和UV 一.Java ...
- Hive 进阶
两种情况下不走map-reduce: 1. where ds >' ' //ds 是partition 2. select * from table //后面没有查询条件,什么都没有 1.建表 ...
- hive进阶 技巧
1.日期格式转换(将yyyymmdd转换为yyyy-mm-dd) select from_unixtime(unix_timestamp('20180905','yyyymmdd'),'yyyy-mm ...
- 大数据学习(10)—— Hive进阶
前面提到了Hive的知识点非常零散,我不知道该怎么把这些知识点分类,跟SQL关系没那么大的就放在这一篇吧. Hive Serde 参考Hive Serde Serde是啥 Serde是序列化和反序列化 ...
- concat_ws 使用在hive spark-sql上的区别
concat_ws() 在hive中,被连接对象必须为string或者array<string>,否则报错如下: hive> select concat_ws(',',unix_ti ...
随机推荐
- IE下图片切换的时候,图片总是切换不成功---根本问题是IE缓存图片
作为WEB设计者,为了在网页展示上加强用户体验,经常会利用图象载入显示状态方法,这自然需要Image对象的onload事件. 在firefox浏览器下完成开发后,可是在IE浏览器中进行调试总不能被调用 ...
- 关于js对象值的传递
结合红宝书和网上的一些文章,记录下自己对关于js对象的值的传递的一些理解. js对象是保存在堆内存中的,当把对象赋值给变量时,是把对象在堆内存的引用(地址)赋值给了变量,变量通过地址来访问对象.下面来 ...
- select Into用法
1. insert into 表(列1,列2) select 列1,列2 from 表2 where.... 2.select * into 表2 from 表 1where... 上面写法标识将表1 ...
- Spring-----3、Spring的核心机制(依赖注入)
转载自:http://blog.csdn.net/hekewangzi/article/details/41345237
- Inno setup卸载前退出进程、删除文件夹
[Code]function InitializeUninstall(): Boolean; var MainRun: HWND; var MVRun:HWND; begin// FindWindow ...
- PS切图保存后的背景图为透明
1.若想PS切图保存后的背景图为透明,那么则需要在如下图中所示的修改即可,切图后[文件]——>[存储为web格式]——>[PNG-24]: 2.要想在css中的背景图片为相通,则先剪切一个 ...
- NET Core开发-读取配置文件Configuration
ASP.NET Core开发-读取配置文件Configuration ASP.NET Core 是如何读取配置文件,今天我们来学习. ASP.NET Core的配置系统已经和之前版本的ASP.NE ...
- javascript instanceof
object instanceof constructor instanceof运算符用来检测constructor.prototype是否存在于参数object的原型链上. 对于instanceof ...
- 第52周二Restful
今天去spring官网发现一个关键词:Restful,以前只在与一个系统对接时用到过这种形式的接口,但印象不深,百度搜索后才感觉自己太out了,这个概念2000年提出,2009年时国内就有很多人推荐使 ...
- 【HDU】4923 Room and Moor(2014多校第六场1003)
Room and Moor Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others) ...