吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 3517|回复: 7
收起左侧

[其他转载] 【分享】Hive基本使用

  [复制链接]
爆炒小提莫 发表于 2019-4-3 05:30
本帖最后由 爆炒小提莫 于 2019-4-3 16:55 编辑

【官方】Apache Hive数据仓库软件有助于使用SQL读取,编写和管理驻留在分布式存储中的大型数据集。可以将结构投影到已存储的数据中。提供了命令行工具和JDBC驱动程序以将用户连接到Hive。


Hive 是大数据领域一个重要的数据仓库框架,能够处理存储在Hadoop的分布式文件系统上的结构化数据,将SQL转为MapReduce任务分配到Hadoop集群上并发的对海量数据进行计算,主流的离线计算框架。这是一种空间换时间的计算方式,数据量小的场景就不建议使用大数据了,传统数据库的优势更大,成本也没有大数据昂贵。

基本建表语句
[SQL] 纯文本查看 复制代码
create table t_a(name string, numb int)

row format delimited

fields terminated by ',';

 

create table t_b(name string, nick string)

row format delimited

fields terminated by ',';

准备两张表的数据
a.txt
[Asm] 纯文本查看 复制代码
a,1
b,2
c,3
d,4

b.txt
[Asm] 纯文本查看 复制代码
a,xx
b,yy
d,zz
e,pp

a.txt导入到t_a表中,将b.txt导入到t_b表中

[SQL] 纯文本查看 复制代码
load data local inpath '/root/test/a.txt' into table t_a;

load data local inpath '/root/test/b.txt' into table t_b;

查询数据
[Asm] 纯文本查看 复制代码
select * from t_a;
select * from t_b;

各类join1. 内连接笛卡儿积
[SQL] 纯文本查看 复制代码
select
a.*, b.*
from t_a a
join t_b b;
两个表的数据行没有指定怎么关联,两个表所有行都相互关联,产生笛卡尔积。左外连接和右外连接没有关联条件也会出现笛卡尔积现象。造成大量的开销,生成大量的数据集。
[Shell] 纯文本查看 复制代码
+---------+---------+---------+---------+--+
| a.name  | a.numb  | b.name  | b.nick  |
+---------+---------+---------+---------+--+
| a       | 1       | a       | xx      |
| b       | 2       | a       | xx      |
| c       | 3       | a       | xx      |
| d       | 4       | a       | xx      |
| a       | 1       | b       | yy      |
| b       | 2       | b       | yy      |
| c       | 3       | b       | yy      |
| d       | 4       | b       | yy      |
| a       | 1       | d       | zz      |
| b       | 2       | d       | zz      |
| c       | 3       | d       | zz      |
| d       | 4       | d       | zz      |
| a       | 1       | e       | pp      |
| b       | 2       | e       | pp      |
| c       | 3       | e       | pp      |
| d       | 4       | e       | pp      |
+---------+---------+---------+---------+--+
指定join条件
[Scala] 纯文本查看 复制代码
select [/b]a.*, b.* 
from t_a a
join t_b b 
on a.name =b.name;

[SQL] 纯文本查看 复制代码
+---------+---------+---------+---------+--+
| a.name  | a.numb  | b.name  | b.nick  |
+---------+---------+---------+---------+--+
| a       | 1       | a       | xx      |
| b       | 2       | b       | yy      |
| d       | 4       | d       | zz      |
+---------+---------+---------+---------+--+

1. 左外连接(左连接)
[SQL] 纯文本查看 复制代码
select 
a.*, b.* 
from t_a a
left join t_b b 
on a.name =b.name;


左表的每一行数据与右表按条件关联,如果符合条件就返回左右两表的行数据,如果不符合关联条件,依旧返回左表的行数据,右表行数据返回null
[SQL] 纯文本查看 复制代码
+---------+---------+---------+---------+--+
| a.name  | a.numb  | b.name  | b.nick  |
+---------+---------+---------+---------+--+
| a       | 1       | a       | xx      |
| b       | 2       | b       | yy      |
| c       | 3       | NULL    | NULL    |
| d       | 4       | d       | zz      |
+---------+---------+---------+---------+--+


2. 右外连接(右连接)
[SQL] 纯文本查看 复制代码
select 
a.*, b.* 
from t_a a
right join t_b b 
on a.name =b.name;

与左外连接相反
[Asm] 纯文本查看 复制代码
+---------+---------+---------+---------+--+
| a.name  | a.numb  | b.name  | b.nick  |
+---------+---------+---------+---------+--+
| a       | 1       | a       | xx      |
| b       | 2       | b       | yy      |
| d       | 4       | d       | zz      |
| NULL    | NULL    | e       | pp      |
+---------+---------+---------+---------+--+


3. 全外连接
[SQL] 纯文本查看 复制代码
select 
a.*, b.* 
from t_a a
full outer join t_b b 
on a.name =b.name;

左表,右表之间关联,全外连接为左外连接与右外连接结果的并集。
[Asm] 纯文本查看 复制代码
+---------+---------+---------+---------+--+
| a.name  | a.numb  | b.name  | b.nick  |
+---------+---------+---------+---------+--+
| a       | 1       | a       | xx      |
| b       | 2       | b       | yy      |
| c       | 3       | NULL    | NULL    |
| d       | 4       | d       | zz      |
| NULL    | NULL    | e       | pp      |
+---------+---------+---------+---------+--+

4.左半连接
左表的数据只返回符合和右表关联条件的数据,右表的数据不返回。
[SQL] 纯文本查看 复制代码
select a.* 
from t_a a
left semi join t_b b 
on a.name =b.name;


[Asm] 纯文本查看 复制代码
+---------+---------+--+
| a.name  | a.numb  |
+---------+---------+--+
| a       | 1       |
| b       | 2       |
| d       | 4       |
+---------+---------+--+

注意:left semi joinselect 字句中,不能有右表的字段


分组聚合查询

准备一个访问日志数据pv_url.log
【url在文档保存的时候被处理了,没法改过来,大家知道是url字符串就行,本来是没有杂的东西加在里面的】
[Asm] 纯文本查看 复制代码
192.168.88.2,[url]https://www.52pojie.cn/2.php[/url],2019-04-03 16:33:07
192.168.88.3,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:06
192.168.88.2,[url]https://www.52pojie.cn/4.php[/url],2019-04-03 16:33:09
192.168.88.2,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:06
192.168.88.0,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:07
192.168.88.1,[url]https://www.52pojie.cn/2.php[/url],2019-04-03 16:33:05
192.168.88.0,[url]https://www.52pojie.cn/1.php[/url],2019-04-03 16:33:14
192.168.88.1,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:06
192.168.88.3,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:12
192.168.88.1,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:07
192.168.88.0,[url]https://www.52pojie.cn/4.php[/url],2019-04-03 16:33:08
192.168.88.3,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:13
192.168.88.3,[url]https://www.52pojie.cn/4.php[/url],2019-04-03 16:33:06
192.168.88.0,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:07
192.168.88.2,[url]https://www.52pojie.cn/4.php[/url],2019-04-03 16:33:13
192.168.88.2,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:05
192.168.88.0,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:11
192.168.88.3,[url]https://www.52pojie.cn/0.php[/url],2019-04-03 16:33:07
192.168.88.0,[url]https://www.52pojie.cn/3.php[/url],2019-04-03 16:33:09
192.168.88.3,[url]https://www.52pojie.cn/1.php[/url],2019-04-03 16:33:14



将数据导入到hive
[SQL] 纯文本查看 复制代码
create table t_pv_log(ip string,url string, dt string)
row format delimited 
fields terminated by ',';

load data local inpath '/root/test/pv_url.log' into table t_pv_log;
select * from  t_pv_log;

[Asm] 纯文本查看 复制代码
+---------------+-------------------------------+----------------------+--+
|  t_pv_log.ip  |         t_pv_log.url          |     t_pv_log.dt      |
+---------------+-------------------------------+----------------------+--+
| 192.168.88.2  | [url]https://www.52pojie.cn/2.php[/url]  | 2019-04-03 16:33:07  |
| 192.168.88.3  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:06  |
| 192.168.88.2  | [url]https://www.52pojie.cn/4.php[/url]  | 2019-04-03 16:33:09  |
| 192.168.88.2  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:06  |
| 192.168.88.0  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:07  |
| 192.168.88.1  | [url]https://www.52pojie.cn/2.php[/url]  | 2019-04-03 16:33:05  |
| 192.168.88.0  | [url]https://www.52pojie.cn/1.php[/url]  | 2019-04-03 16:33:14  |
| 192.168.88.1  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:06  |
| 192.168.88.3  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:12  |
| 192.168.88.1  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:07  |
| 192.168.88.0  | [url]https://www.52pojie.cn/4.php[/url]  | 2019-04-03 16:33:08  |
| 192.168.88.3  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:13  |
| 192.168.88.3  | [url]https://www.52pojie.cn/4.php[/url]  | 2019-04-03 16:33:06  |
| 192.168.88.0  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:07  |
| 192.168.88.2  | [url]https://www.52pojie.cn/4.php[/url]  | 2019-04-03 16:33:13  |
| 192.168.88.2  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:05  |
| 192.168.88.0  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:11  |
| 192.168.88.3  | [url]https://www.52pojie.cn/0.php[/url]  | 2019-04-03 16:33:07  |
| 192.168.88.0  | [url]https://www.52pojie.cn/3.php[/url]  | 2019-04-03 16:33:09  |
| 192.168.88.3  | [url]https://www.52pojie.cn/1.php[/url]  | 2019-04-03 16:33:14  |
+---------------+-------------------------------+----------------------+--+


求每条url的访问次数
[SQL] 纯文本查看 复制代码
select url, count(1) --该表达式是对很好组的数据进行逐行运算
from t_pv_log
group by url;

[Asm] 纯文本查看 复制代码
0: jdbc:hive2://hdp:10000> select url, count(1) from t_pv_log group by url;
+-------------------------------+------+--+
|              url              | _c1  |
+-------------------------------+------+--+
| [url]https://www.52pojie.cn/0.php[/url]  | 6    |
| [url]https://www.52pojie.cn/1.php[/url]  | 2    |
| [url]https://www.52pojie.cn/2.php[/url]  | 2    |
| [url]https://www.52pojie.cn/3.php[/url]  | 6    |
| [url]https://www.52pojie.cn/4.php[/url]  | 4    |
+-------------------------------+------+--+

免费评分

参与人数 4吾爱币 +5 热心值 +4 收起 理由
xwl + 1 + 1 热心回复!
苏紫方璇 + 3 + 1 欢迎分析讨论交流,吾爱破解论坛有你更精彩!
q314956820 + 1 内容极度不适应 好想哭
jc021227 + 1 + 1 我很赞同!

查看全部评分

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

y20286284 发表于 2019-4-3 08:09
内容通俗易懂,谢谢
haorenmo 发表于 2019-4-3 08:12
a276214180 发表于 2019-4-3 08:25
DEFwa 发表于 2019-4-3 08:49
谢谢分享,支持好帖!!
bcs000 发表于 2019-4-3 09:14
谢谢分享,没大明白说的啥
很赞哦 发表于 2021-3-18 16:24
谢谢楼主
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2025-1-16 05:11

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表