Hive基础知识整理(1)

参考链接:视频教程
慕课网–走进Hive

一、数据仓库

数据仓库是一个面向主题的(有特定需求)、集成的(来自多个源)、不可更新的(只做查询操作)、随时间不变化的数据集合。它用于支持企业或组织的决策分析处理。

1、数据仓库的结构和建立过程: 《Hive基础知识整理(1)》 数据仓库的结构和建立过程

2、OLTP && OLAP

OLTP:联机事务处理过程,面向事物,如银行转账系统
OLAP:联机事物分析,面向查询,如商品推荐系统

3、数据仓库中的数据模型:

星型模型——》雪花模型

《Hive基础知识整理(1)》 星型模型

《Hive基础知识整理(1)》 雪花模型

二、Hive

1、什么是Hive

(1) 建立在Hadoop HDFS上的数据仓库基础架构
(2) 可以用来进行ETL
(3) 定义了类似于SQL,成为HQL
(4) 允许MapReduce自定义

Hive是SQL解析引擎,将SQL——》M/R job

Hive的表其实就是HDFS的目录/文件

2、Hive的体系结构

《Hive基础知识整理(1)》 hive体系结构

Hive的元数据:

《Hive基础知识整理(1)》 Hive元数据

  • Hive将元数据存储在数据库中(Metestore),支持mysql、derby(默认)等
  • Hive中的元数据包括表的名字、表的列、分区及其属性、表的属性等。

HQL的执行过程:

《Hive基础知识整理(1)》 HQL执行过程

  • 解释器、编译器、优化器完成HQL查询语句从词法分析、语法分析、编译、优化以及查询技术(plan)的生成。生成的查询技术存储在HDFS中,并随后有MapReduce调用执行。

3、Hive的安装

Hive依赖于Hadoop的安装

Hadoop的安装:
(1)单机环境
(2)伪分布式环境
(3)集群环境

Hive的安装模式:三种

(1)嵌入模式
  • 元数据信息存储在Hive自带的derby数据库中
  • 只允许创建一个链接
  • 多用于做demo演示
(2)本地模式
  • 元数据信息被存储在Mysql数据库中
  • Mysql数据库和Hive运行在同一台物理机器上
    -多用于开发和测试
(3)远程模式
  • Hive和MYsql运行在不同机器上,多用于生产环境
  • 允许多个连接

4、Hive的启动方式:

(1) CLI命令行方式
(2) Web界面方式
默认端口号:9999
启动方式:

hive –service hwi &

通过浏览器来访问:http://<ip地址>:9999/hwi/
(3) 远程服务启动方式
端口号:10000
启动方式:

hive –service hwi &

5、Hive的数据类型

(1)基本数据类型

  • tinyint/smallint/int/bigint:整数类型
  • float/double:浮点数类型
  • boolean:布尔类型
  • string:字符串类型
    (2)复杂数据类型
  • Array:数组类型。一系列相同数据类型的元素
  • Map :key-value键值对
  • struct:结构类型:可以包含不同数据类型的元素
    (3)时间类型
  • Date 格式如YYYY-MM-DD
  • TimeStamp 为自1970年起秒数
    注:在Hive中两者相互转换的函数:cast()

6、Hive的数据存储

(1)基于HDFS
(2)没有专门的数据存储格式
(3)存储结构主要包括:数据库、文件、表、试图
(4)可以直接加载文本文件(.txt)
(5)创建表时,可以指定Hive的列分隔符与行分隔符(默认无分隔符)

7、Hive的数据模型

(1)内部表(table)

  • 与数据库中的table概念是类似的
  • 每一个Table在Hive中都有一个相应的目录存储数据
  • 所有的Table(不包括Txternal Tale)都保存在这个目录中
  • 删除表时,元数据与数据都会被删除

例:

Create table T1
(Tid int,tname string,age int)

Create table T2
(Tid int,tname string,age int)
Location ‘/mytable/hive/t2’
–指定表存储位置

Create table T3
(Tid int,tname string,age int)
Row format delimited fields terminated by ‘,’
–指定行的分隔符是逗号

Create table T4
as
select * from sample_data
–创建表的同时创建数据,用查询语句创建数据,t4表内容与结构与表sample_data相同

Create table T5
Row format delimited fields terminated by ‘,’
as
select * from sample_data

Alter table T1 add columns(English int)
–T1表加了一列,改变表的结构

(2)分区表

  • partition对应于数据库的Partion列的密集索引
  • 在Hive中,表中的一个Partition对应于表下的一个目录,所有的partition的数据都存储在对应的目录中。

    《Hive基础知识整理(1)》 分区表示意

例:

Create table Partion_table
(sid int,sname,string)
Partition by (gender string)
Row format delimited fields terminated by ‘,’
—创建分区表

Insert into table partition_table partition(gender=’F’)
Select sid,sname from sample_data where gender=’F’

分区表作用:在查询操作时,降低扫描次数,提高查询效率

如何知道查询效率提高,生成执行计划

explain select * from T where gender=‘M’

(3)外部表(extennal table)

  • 执行已经在HDFS中存储的数据,可以创建Partition

  • 他和内部表在元数据的组织上是相同的,而实际数据的存储则有较大的差异

  • 外部表只有一个过程,加载数据和创建表同时完成,并不会移动到数据仓库目录中,只是与外部数据建立一个链接。当删除一个外部表时,仅仅删除该链接。

    《Hive基础知识整理(1)》 外部表示意

例:

Create external table external_student
(Tid int,tname string,age int)
Row format delimited fields terminated by ‘,’
Location ‘/input’

(4) 桶表(Bucket table)

  • 桶表是对数据进行哈希取值,然后放到不同文件中存储。(把数据打散进行存储,避免造成”热块“)
    《Hive基础知识整理(1)》 桶表示意

Create table bucket_table
(Tid int,tname string,age int)
clusterd  by(sname) into 5 buckets;
–根据sname字段进行哈希运算,放入5个桶中

(5) 视图(view)

  • 是一个虚表,是一个逻辑概念
  • 建立在已有表的基础上,试图赖以建立的这些表成为基表
  • 视图可以简化复杂的查询

Create View empinfo
as
select e.emptno,e.ename,e.sale,e.sale*12 annlsal d.dname
from emp e,dept d
where e.deptno=d.deptno

其他知识点:

静默模式:不显示map/reduce过程
命令行:

hive -S

    原文作者:向花开阳阳
    原文地址: https://www.jianshu.com/p/186ee03fff18
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞