目录
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’ |
| 时间频率间隔 |
| |
集合类型 | 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
先创建一张表
准备数据文件 array.txt
加载数据文件到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) 先创建一张表
- 准备数据文件 map.txt
加载数据文件到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) 先创建一张表
准备数据文件 struct.txt
加载数据文件到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 TABLE | create table | 创建一个指定名字的表。如果相同名字的表已经存在,则抛出异常;用户可以用 IF NOT EXISTS 选项来忽略这个异常。 |
EXTERNAL | external | 关键字可以让用户创建一个外部表,在建表的同时指定一个指向实际数据的路径(LOCATION),Hive 创建内部表时,会将数据移动到数据仓库指向的路径;若创建外部表,仅记录数据所在的路径,不对数据的位置做任何改变。在删除表的时候,内部表的元数据和数据会被一起删除,而外部表只删除元数据,不删除数据。 |
LIKE | like | 允许用户复制现有的表结构,但是不复制数据。 |
ROW FORMAT DELIMITED | row format delimited |
|
STORED AS | stored as | SEQUENCEFILE|TEXTFILE|RCFILE 如果文件数据是纯文本,可以使用 STORED AS TEXTFILE。如果数据需要压缩,使用 STORED AS SEQUENCEFILE。 |
CLUSTERED BY | clustere by | 对于每一个表(table)或者分区, Hive可以进一步组织成桶,也就是说桶是更为细粒度的数据范围划分。Hive也是 针对某一列进行桶的组织。Hive采用对列值哈希,然后除以桶的个数求余的方式决定该条记录存放在哪个桶当中。 把表(或者分区)组织成桶(Bucket)有两个理由:
|