`

hive的数据类型和数据模型

    博客分类:
  • hive
 
阅读更多

在上篇文章里,我列举了一个简单的hive操作实例,创建了一张表test,并且向这张表加载了数据,这些操作和关系数据库操作类似,我们常把hive和关系数据库进行比较,也正是因为hive很多知识点和关系数据库类似。

  关系数据库里有表(table),分区,hive里也有这些东西,这些东西在hive技术里称为hive的数据模型。今天本文介绍hive的数据类型,数据模型以及文件存储格式。这些知识大家可以类比关系数据库的相关知识。

  首先我要讲讲hive的数据类型。

  Hive支持两种数据类型,一类叫原子数据类型,一类叫复杂数据类型。

  原子数据类型包括数值型、布尔型和字符串类型,具体如下表所示:

基本数据类型

类型

描述

示例

TINYINT

1个字节(8位)有符号整数

1

SMALLINT

2字节(16位)有符号整数

1

INT

4字节(32位)有符号整数

1

BIGINT

8字节(64位)有符号整数

1

FLOAT

4字节(32位)单精度浮点数

1.0

DOUBLE

8字节(64位)双精度浮点数

1.0

BOOLEAN

true/false

true

STRING

字符串

‘xia’,”xia”

 

  由上表我们看到hive不支持日期类型,在hive里日期都是用字符串来表示的,而常用的日期格式转化操作则是通过自定义函数进行操作。

  hive是用java开发的,hive里的基本数据类型和java的基本数据类型也是一一对应的,除了string类型。有符号的整数类型:TINYINT、SMALLINT、INT和BIGINT分别等价于java的byte、short、int和long原子类型,它们分别为1字节、2字节、4字节和8字节有符号整数。Hive的浮点数据类型FLOAT和DOUBLE,对应于java的基本类型float和double类型。而hive的BOOLEAN类型相当于java的基本数据类型boolean。

  对于hive的String类型相当于数据库的varchar类型,该类型是一个可变的字符串,不过它不能声明其中最多能存储多少个字符,理论上它可以存储2GB的字符数。

  Hive支持基本类型的转换,低字节的基本类型可以转化为高字节的类型,例如TINYINT、SMALLINT、INT可以转化为FLOAT,而所有的整数类型、FLOAT以及STRING类型可以转化为DOUBLE类型,这些转化可以从java语言的类型转化考虑,因为hive就是用java编写的。当然也支持高字节类型转化为低字节类型,这就需要使用hive的自定义函数CAST了。

  复杂数据类型包括数组(ARRAY)、映射(MAP)和结构体(STRUCT),具体如下表所示:

复杂数据类型

类型

描述

示例

ARRAY

一组有序字段。字段的类型必须相同

Array(1,2)

MAP

一组无序的键/值对。键的类型必须是原子的,值可以是任何类型,同一个映射的键的类型必须相同,值得类型也必须相同

Map(‘a’,1,’b’,2)

STRUCT

一组命名的字段。字段类型可以不同

Struct(‘a’,1,1,0)

 

下面我们看看hive使用复杂数据类型的实例,建表:

Create table complex(col1 ARRAY<INT>,
Col2 MAP<STRING,INT>,
Col3 STRUCT<a:STRING,b :INT,c:DOUBLE>);

  

查询语句:

Select col1[0],col2[‘b’],col3.c from complex;

  

  接下来我们来看看hive的数据模型,hive的数据模型包括:database、table、partition和bucket。下面我将一一论述这四种数据模型。

1.Database:相当于关系数据库里的命名空间(namespace),它的作用是将用户和数据库的应用隔离到不同的数据库或模式中,该模型在hive 0.6.0之后的版本支持,hive提供了create database dbname、use dbname以及drop database dbname这样的语句。

2.表(table):hive的表逻辑上由存储的数据和描述表格中的数据形式的相关元数据组成。表存储的数据存放在分布式文件系统里,例如HDFS,元数据存储在关系数据库里,当我们创建一张hive的表,还没有为表加载数据的时候,该表在分布式文件系统,例如hdfs上就是一个文件夹(文件目录)。Hive里的表友两种类型一种叫托管表,这种表的数据文件存储在hive的数据仓库里,一种叫外部表,这种表的数据文件可以存放在hive数据仓库外部的分布式文件系统上,也可以放到hive数据仓库里(注意:hive的数据仓库也就是hdfs上的一个目录,这个目录是hive数据文件存储的默认路径,它可以在hive的配置文件里进行配置,最终也会存放到元数据库里)。

下面是创建托管表的实例语句:

 

Create table tuoguan_tbl (flied string);
Load data local inpath ‘home/hadoop/test.txt’ into table tuoguan_tbl;

  

外部表创建的实例:

Create external table external_tbl (flied string)
    Location  ‘/home/hadoop/external_table’;
Load data local inpath ‘home/hadoop/test.txt’ into table external_tbl;

  

  大家看到了创建外部表时候table之前要加关键字external,同时还要用location命令指定文件存储的路径,如果不使用locaction数据文件也会放置到hive的数据仓库里。

  这两种表在使用的区别主drop命令上,drop是hive删除表的命令,托管表执行drop命令的时候,会删除元数据和存储的数据,而外部表执行drop命令时候只删除元数据库里的数据,而不会删除存储的数据。另外我还要谈谈表的load命令,hive加载数据时候不会对元数据进行任何检查,只是简单的移动文件的位置,如果源文件格式不正确,也只有在做查询操作时候才能发现,那个时候错误格式的字段会以NULL来显示。

 3.分区(partition):hive里分区的概念是根据“分区列”的值对表的数据进行粗略划分的机制,在hive存储上就体现在表的主目录(hive的表实际显示就是一个文件夹)下的一个子目录,这个文件夹的名字就是我们定义的分区列的名字,没有实际操作经验的人可能会认为分区列是表的某个字段,其实不是这样,分区列不是表里的某个字段,而是独立的列,我们根据这个列存储表的里的数据文件。使用分区是为了加快数据分区的查询速度而设计的,我们在查询某个具体分区列里的数据时候没必要进行全表扫描。下面我就举一个分区使用的实例:

创建分区:

Create table logs(ts bigint,line string)
Partitioned by (dt string,country string);

  

 

加载数据:

Local data local inpath ‘/home/hadoop/par/file01.txt’ into table logs partition (dt=’2012-06-02’,country=’cn’);

  

 

在hive数据仓库里实际存储的路径如下所示:

/user/hive/warehouse/logs/dt=2013-06-02/country=cn/file1.txt
/user/hive/warehouse/logs/dt=2013-06-02/country=cn/file2.txt
/user/hive/warehouse/logs/dt=2013-06-02/country=us/file3.txt
/user/hive/warehouse/logs/dt=2013-06-02/country=us/file4.txt

  

 

我们看到在表logs的目录下有了两层子目录dt=2013-06-02和country=cn

查询操作:

Select ts,dt,line  from logs where country=’cn’,

  

这个时候我们的查询操作只会扫描file1.txt和file2.txt文件。

4.桶(bucket):上面的table和partition都是目录级别的拆分数据,bucket则是对数据源数据文件本身来拆分数据。使用桶的表会将源数据文件按一定规律拆分成多个文件,要使用bucket,我们首先要打开hive对桶的控制,命令如下:

set hive.enforce.bucketing = true

  

下面这段文字是我引用博客园里风生水起的博文:

示例:
建临时表student_tmp,并导入数据:
hive> desc student_tmp;        
OK
id      int
age     int
name    string
stat_date       string
Time taken: 0.106 seconds
hive> select * from student_tmp;
OK
1       20      zxm     20120801
2       21      ljz     20120801
3       19      cds     20120801
4       18      mac     20120801
5       22      android 20120801
6       23      symbian 20120801
7       25      wp      20120801
Time taken: 0.123 seconds
 
建student表:
hive>create table student(id INT, age INT, name STRING)
       >partitioned by(stat_date STRING)
       >clustered by(id) sorted by(age) into 2 bucket
       >row format delimited fields terminated by ',';
 
设置环境变量:
       >set hive.enforce.bucketing = true;
 
插入数据:
 
       >from student_tmp
       >insert overwrite table student partition(stat_date="20120802")
       >select id,age,name where stat_date="20120801" sort by age;
 
查看文件目录:
$ hadoop fs -ls /user/hive/warehouse/studentstat_date=20120802/
Found 2 items
-rw-r--r--   1 work supergroup         31 2012-07-31 19:52 /user/hive/warehouse/student/stat_date=20120802/000000_0
-rw-r--r--   1 work supergroup         39 2012-07-31 19:52 /user/hive/warehouse/student/stat_date=20120802/000001_0

  

  物理上,每个桶就是表(或分区)目录里的一个文件,桶文件是按指定字段值进行hash,然后除以桶的个数例如上面例子2,最后去结果余数,因为整数的hash值就是整数本身,上面例子里,字段hash后的值还是字段本身,所以2的余数只有两个0和1,所以我们看到产生文件的后缀是*0_0和*1_0,文件里存储对应计算出来的元数据。

  Hive的桶,我个人认为没有特别的场景或者是特别的查询,我们可以没有必要使用,也就是不用开启hive的桶的配置。因为桶运用的场景有限,一个是做map连接的运算,我在后面的文章里会讲到,一个就是取样操作了,下面还是引用风生水起博文里的例子:

查看sampling数据:
hive> select * from student tablesample(bucket 1 out of 2 on id);                                                                              
Total MapReduce jobs = 1
Launching Job 1 out of 1
.......
OK
4       18      mac     20120802
2       21      ljz     20120802
6       23      symbian 20120802
Time taken: 20.608 seconds
 
tablesample是抽样语句,语法:TABLESAMPLE(BUCKET x OUT OF y)
y必须是table总bucket数的倍数或者因子。hive根据y的大小,决定抽样的比例。例如,table总共分了64份,当y=32时,抽取 (64/32=)2个bucket的数据,当y=128时,抽取(64/128=)1/2个bucket的数据。x表示从哪个bucket开始抽取。例 如,table总bucket数为32,tablesample(bucket 3 out of 16),表示总共抽取(32/16=)2个bucket的数据,分别为第3个bucket和第(3+16=)19个bucket的数据。

  

  好了,今天就写到这里了,明天要上班不能在加班写文章了。这篇博文的内容并没有写完(hive存储格式没有写),因为这个章节的知识非常重要是理解hive的关键,所以要讲的细点,明天我争取写完hive存储格式的文章,后天也就是本周二,我将为我们技术部门介绍hive的相关技术,写博文算是我的预演了。

  最后我要讲一下自己对大数据技术的看法,我觉得大数据技术是一个跨时代的技术,是互联网技术的未来,也是云计算的未来,它的深入发展不仅仅是数据处理上,也会改变整个互联网技术的生态链,包括我们使用的技术和开发语言,很庆幸亲身经历着整个伟大时代的变革,我也要展开双臂迎接这个大时代的到来。

分享到:
评论

相关推荐

    hive数据类型共6页.pdf.zip

    - **MAP,V&gt;**:键值对的集合,K和V可以是任意Hive数据类型。 - **STRUCT, field2 type2, ...&gt;**:结构体,包含多个字段,每个字段有自己的数据类型。 - **UNIONTYPE, T2, ..., Tk&gt;**:联合类型,可以是多个其他...

    hive数据模型操作.pdf

    本篇内容主要讲解了 Hive 数据模型的操作,包括数据库和内部表的相关操作。 一、Hive 数据库操作 1. 创建数据库:使用 `CREATE DATABASE` 语句可以创建数据库,`IF NOT EXISTS` 可避免重复创建。例如: ```sql ...

    hive测试数据

    通常,Hive测试数据会包含多个表,每个表可能有不同的列和数据类型,用于展示Hive的各种查询和转换功能。 在实际使用Hive时,有以下几个关键知识点: 1. **Hive架构**:Hive由元存储、驱动器、编译器、执行器等...

    hive 操作相关的测试数据集

    测试数据集通常包含各种场景,如不同数据类型、复杂查询、性能测试等,以全面检验Hive的功能和性能。通过分析和操作这个“hive操作相关的测试数据集”,用户可以深入了解Hive的实际应用,并提升在大数据环境下的数据...

    Hive总结.docx

    Hive是基于Hadoop平台的数据仓库解决方案,它主要解决了在大数据场景下,业务人员和数据科学家能够通过熟悉的SQL语言进行数据分析的问题。Hive并不存储数据,而是依赖于HDFS进行数据存储,并利用MapReduce、Tez或...

    Hive大数据仓库-笔记整理 (一)2020年最新版.pdf

    4. **Hive数据类型**:Hive支持多种数据类型,包括基本类型(如STRING, INT, BOOLEAN)和复杂类型(如ARRAY, MAP, STRUCT)。 5. **HQL语法**:HQL支持SELECT, FROM, WHERE, GROUP BY, JOIN等SQL关键字,允许用户...

    基于hadoop平台hive数据库处理电影数据(8965字数32页).doc

    同时,对于Hive数据库的设计,可能会涉及数据模型的定义,如创建表、分区策略、数据类型选择等,以适应电影数据的特点和分析需求。 总的来说,这篇文档提供了一个完整的基于Hadoop和Hive的大数据处理解决方案,适用...

    hive数据仓库的建立.zip

    总的来说,建立Hive数据仓库涉及了从环境搭建、数据模型设计、数据加载到查询执行等多个环节,每个环节都需要仔细考虑和规划,以实现高效的数据管理和分析。通过实践和不断学习,你将能够熟练掌握Hive,成为大数据...

    mysql数据抽取,自动生成hive建表语句

    3. **映射数据类型**:将MySQL的数据类型映射到Hive支持的数据类型。例如,MySQL的INT映射为Hive的INT,VARCHAR映射为STRING等。 4. **处理分区**:如果需要在Hive中创建分区表,可以分析MySQL表中的时间戳或分类...

    HIVE从入门到精通.pdf

    Hive支持表、外部表、分区和桶等数据模型。 #### 二、Hive的安装与配置 - **安装流程**:首先需要确保已经正确安装了Hadoop环境,然后下载Hive并解压至适当位置,接着配置Hive的环境变量以及相关配置文件。 - **...

    基于Hadoop_Hive的气象数据分布式处理研究.pdf

    半结构化数据是介于结构化数据和非结构化数据之间的一种数据类型,它没有固定的数据模型,但是却包含了比完全非结构化数据更多的数据组织信息。气象数据通常包含了大量的日志数据,这些数据通常以半结构化的形式存储...

    大数据分析与应用Hadoop-Hive.pptx

    Hive与传统的RDBMS(关系型数据库管理系统)相比,具有更灵活的数据模型和更高的扩展性,但在查询性能上可能稍逊一筹。 ### 四、手厅数据过滤实践 在实际应用中,Hive可以用于对数据进行过滤和筛选。例如,创建一...

    Hive、MySQL、HBase数据互导

    1. **Hive概念与基本原理**:了解Hive的数据模型,如表、分区、桶等,以及HiveQL语言,包括数据类型、查询语句、JOIN操作等。理解Hive如何将SQL查询转换为MapReduce作业在Hadoop上执行。 2. **关系数据库概念与基本...

    hive测试题(包含万级测试数据文件)

    2. **ratings.txt、movies.txt、users.txt** - 这些可能是模拟的数据库文件,用于构建一个简化的电影推荐系统或者类似的数据模型。"ratings.txt"可能包含用户对电影的评分,"movies.txt"可能存储电影的元数据,如...

    HIVE-SQL开发规范.docx

    Hive支持TINYINT(1字节),SMALLINT(2字节),INT(4字节)和BIGINT(8字节)四种整型数据类型。选择合适的数据类型可以有效节省存储空间。 2.1.2 浮点型 Hive支持FLOAT和DOUBLE两种浮点类型,用于表示近似数值。...

    Hive编程1

    Hive数据类型 Hive支持多种数据类型,包括基本类型、复杂类型和用户自定义类型。基本类型包括整数、浮点数、字符串、日期和时间等。复杂类型包括数组、结构体和映射等。用户可以根据需要定义自己的数据类型。 ...

    hive编程入门课程

    4. **简单易用**:Hive提供了丰富的数据类型、数据模型以及DDL和DML语句,使得数据的加载、查询、更新等操作变得简单直观。 #### 三、Hive的数据模型与类型 Hive支持多种数据类型,包括原始类型如整型(int、bigint...

    大数据hive实现原理.zip_hive中怎么更新数据

    因此,在设计Hive数据模型时,应尽可能减少UPDATE和DELETE操作,优先考虑INSERT和REPLACE INTO等方法来维护数据。 在实际应用中,Hive更新数据通常涉及以下步骤: 1. **创建一个临时表**:用于存放更新后的数据。 2...

    Apache Web日志Hive实验数据

    Apache Web日志Hive实验数据是针对大数据处理和分析领域的一个常见练习,主要涉及Apache Hive这一强大的大数据处理工具。Apache Hive是一种基于Hadoop的数据仓库工具,它可以将结构化的数据文件映射为一张数据库表,...

Global site tag (gtag.js) - Google Analytics