目录
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)基础数据类型:
(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 ':' |
- 准备数据文件 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 |
用户在建表的时候可以自定义 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)更高效。在处理大规模数据集时,在开发和修改查询的阶段,如果能在数据集的一小部分数据上试运行查询,会带来很多方便。 |