美文网首页hive程序员工具癖
Hive基础知识整理(1)

Hive基础知识整理(1)

作者: 花生花二三说 | 来源:发表于2018-02-22 23:10 被阅读545次

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

    一、数据仓库

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

    1、数据仓库的结构和建立过程: 数据仓库的结构和建立过程

    2、OLTP && OLAP

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

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

    星型模型——》雪花模型


    星型模型
    雪花模型

    二、Hive

    1、什么是Hive

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

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

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

    2、Hive的体系结构

    hive体系结构

    Hive的元数据:


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

    HQL的执行过程:


    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的数据都存储在对应的目录中。


      分区表示意

    例:

    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

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

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

      外部表示意

    例:

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

    (4) 桶表(Bucket table)

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

    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

    相关文章

      网友评论

        本文标题:Hive基础知识整理(1)

        本文链接:https://www.haomeiwen.com/subject/qeftxftx.html