目录

Hive的内置数据类型可以分为两大类:

(1)基础数据类型:

(2)集合数据类型

(2.1)集合类型之array

(2.1)集合类型之map

(2.3)集合类型之struct

语法代码:

代码详解:


Hive的内置数据类型可以分为两大类:

(1)、基础数据类型;(2)、集合数据类型

分类

类型

描述

字面量示例

原始类型

BOOLEAN

true/false

TRUE

 

TINYINT

1字节的有符号整数 -128~127

1Y

 

SMALLINT

2个字节的有符号整数,-32768~32767

1S

 

INT

4个字节的带符号整数

1

 

BIGINT

8字节带符号整数

1L

 

FLOAT

4字节单精度浮点数1.0

 

 

DOUBLE

8字节双精度浮点数

1.0

 

DEICIMAL

任意精度的带符号小数

1.0

 

STRING

字符串,变长

“a”,’b’

 

VARCHAR

变长字符串

“a”,’b’

 

CHAR

固定长度字符串

“a”,’b’

 

BINARY

字节数组

无法表示

 

TIMESTAMP

时间戳,毫秒值精度

122327493795

 

DATE

日期

‘2016-03-29’

 

​INTERVAL​

时间频率间隔

 

集合类型

ARRAY

有序的的同类型的集合

array(1,2)

 

MAP

key-value,key必须为原始类型,value可以任意类型

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

 

STRUCT

字段集合,类型可以不同

struct(‘1’,1,1.0), named_stract(‘col1’,’1’,’col2’,1,’clo3’,1.0)

 

UNION

在有限取值范围内的一个值

create_union(1,’a’,63)

(英文网站:hive数据类型介绍)​​https://cwiki.apache.org/confluence/display/Hive/LanguageManual+Types​

 

(1)基础数据类型:

hive的数据类型与语法详解_数据

 

(2)集合数据类型

集合类型主要包括:array,map,struct等,hive的特性支持集合类型,这特性是关系型数据库所不支持的,利用好集合类型可以有效提升SQL的查询速率。

 

(2.1)集合类型之array

先创建一张表

create table t_array(id int,name string,hobby array<string>)
row format delimited
fields terminated by ','
collection items terminated by '-';

 

准备数据文件 array.txt

 

1,zhangsan,唱歌-跳舞-游泳
2,lisi,打游戏-篮球

 

加载数据文件到t_array表中

load data local inpath ‘/root/array.txt’ into table t_array;

查询数据

select id ,name,hobby[0],hobby[1] from t_array;

注意:array的访问元素和java中是一样的,这里通过索引来访问。

(2.1)集合类型之map

(1) 先创建一张表

create table t_map(id int,name string,hobby map<string,string>)
row format delimited
fields terminated by ','
collection items terminated by '-'
map keys terminated by ':'

 

  1. 准备数据文件 map.txt

 

1,zhangsan,唱歌:非常喜欢-跳舞:喜欢-游泳:一般般
2,lisi,打游戏:非常喜欢-篮球:不喜欢

 

加载数据文件到t_map表中

load data local inpath ‘/root/map.txt’ into table t_map;

查询数据

select id,name,hobby['唱歌'] from t_map;

注意:map的访问元素中的value和java中是一样的,这里通过key来访问。

(2.3)集合类型之struct

(1) 先创建一张表

create table t_struct(id int,name string,address struct<country:string,city:string>)
row format delimited
fields terminated by ','
collection items terminated by '-';

 

准备数据文件 struct.txt

 

1,zhangsan,china-beijing
2,lisi,USA-newyork

 

加载数据文件到t_struct表中

load data local inpath  ‘/root/struct.txt’  into table t_struct;

查询数据

select id,name,address.country,address.city from t_struct;

总结:struct访问元素的方式是通过.符号

 

语法代码:

CREATE [EXTERNAL] TABLE [IF NOT EXISTS] table_name 
[(col_name data_type [COMMENT col_comment], ...)]
[COMMENT table_comment]
[PARTITIONED BY (col_name data_type [COMMENT col_comment], ...)]
[CLUSTERED BY (col_name, col_name, ...)
[SORTED BY (col_name [ASC|DESC], ...)] INTO num_buckets BUCKETS]
[ROW FORMAT row_format]
[STORED AS file_format]
[LOCATION hdfs_path]

代码详解:

大写

小写

功能介绍

CREATE TABLE

create table

创建一个指定名字的表。如果相同名字的表已经存在,则抛出异常;用户可以用 IF NOT EXISTS 选项来忽略这个异常。

EXTERNAL

external

关键字可以让用户创建一个外部表,在建表的同时指定一个指向实际数据的路径(LOCATION),Hive 创建内部表时,会将数据移动到数据仓库指向的路径;若创建外部表,仅记录数据所在的路径,不对数据的位置做任何改变。在删除表的时候,内部表的元数据和数据会被一起删除,而外部表只删除元数据,不删除数据。

LIKE

like

允许用户复制现有的表结构,但是不复制数据。

ROW FORMAT DELIMITED

row

format

delimited

  • ROW FORMAT DELIMITED [FIELDS TERMINATED BY char] [COLLECTION ITEMS TERMINATED BY char]  [MAP KEYS TERMINATED BY char] [LINES TERMINATED BY char] | SERDE serde_name [WITH SERDEPROPERTIES (property_name=property_value, property_name=property_value, ...)]

用户在建表的时候可以自定义 SerDe 或者使用自带的 SerDe。如果没有指定 ROW FORMAT 或者 ROW FORMAT DELIMITED,将会使用自带的 SerDe。在建表的时候,用户还需要为表指定列,用户在指定表的列的同时也会指定自定义的 SerDe,Hive通过 SerDe 确定表的具体的列的数据。

STORED AS

stored

as

SEQUENCEFILE|TEXTFILE|RCFILE

如果文件数据是纯文本,可以使用 STORED AS TEXTFILE。如果数据需要压缩,使用 STORED AS SEQUENCEFILE。

CLUSTERED BY

clustere

by

对于每一个表(table)或者分区, Hive可以进一步组织成桶,也就是说桶是更为细粒度的数据范围划分。Hive也是 针对某一列进行桶的组织。Hive采用对列值哈希,然后除以桶的个数求余的方式决定该条记录存放在哪个桶当中。

把表(或者分区)组织成桶(Bucket)有两个理由:

(1)获得更高的查询处理效率。桶为表加上了额外的结构,Hive 在处理有些查询时能利用这个结构。具体而言,连接两个在(包含连接列的)相同列上划分了桶的表,可以使用 Map 端连接 (Map-side join)高效的实现。比如JOIN操作。对于JOIN操作两个表有一个相同的列,如果对这两个表都进行了桶操作。那么将保存相同列值的桶进行JOIN操作就可以,可以大大较少JOIN的数据量。

(2)使取样(sampling)更高效。在处理大规模数据集时,在开发和修改查询的阶段,如果能在数据集的一小部分数据上试运行查询,会带来很多方便。