转载自:http://blog.csdn.net/chenxingzhen001/article/details/20901045

Hive的内置数据类型可以分为两大类:(1)、基础数据类型;(2)、复杂数据类型。其中,基础数据类型包括:TINYINT,SMALLINT,INT,BIGINT,BOOLEAN,FLOAT,DOUBLE,STRING,BINARY,TIMESTAMP,DECIMAL,CHAR,VARCHAR,DATE。下面的表格列出这些基础类型所占的字节以及从什么版本开始支持这些类型。

数据类型 所占字节 开始支持版本
TINYINT 1byte,-128 ~ 127
SMALLINT 2byte,-32,768 ~ 32,767
INT 4byte,-2,147,483,648 ~ 2,147,483,647
BIGINT 8byte,-9,223,372,036,854,775,808 ~ 9,223,372,036,854,775,807
BOOLEAN
FLOAT 4byte单精度
DOUBLE 8byte双精度
STRING
BINARY 从Hive0.8.0开始支持
TIMESTAMP 从Hive0.8.0开始支持
DECIMAL 从Hive0.11.0开始支持
CHAR 从Hive0.13.0开始支持
VARCHAR 从Hive0.12.0开始支持
DATE 从Hive0.12.0开始支持
  复杂类型包括ARRAY,MAP,STRUCT,UNION,这些复杂类型是由基础类型组成的。

  ARRAY:ARRAY类型是由一系列相同数据类型的元素组成,这些元素可以通过下标来访问。比如有一个ARRAY类型的变量fruits,它是由['apple','orange','mango']组成,那么我们可以通过fruits[1]来访问元素orange,因为ARRAY类型的下标是从0开始的;
  MAP:MAP包含key->value键值对,可以通过key来访问元素。比如”userlist”是一个map类型,其中username是key,password是value;那么我们可以通过userlist['username']来得到这个用户对应的password;
  STRUCT:STRUCT可以包含不同数据类型的元素。这些元素可以通过”点语法”的方式来得到所需要的元素,比如user是一个STRUCT类型,那么可以通过user.address得到这个用户的地址。
  UNION: UNIONTYPE,他是从Hive 0.7.0开始支持的。
  创建一个包含复制类型的表格可以如下

[java] view plaincopy在CODE上查看代码片派生到我的代码片
CREATE TABLE employees (
name STRING,
salary FLOAT,
subordinates ARRAY<STRING>,
deductions MAP<STRING, FLOAT>,
address STRUCT<street:STRING, city:STRING, state:STRING, zip:INT>
) PARTITIONED BY (country STRING, state STRING);

最新文章

  1. AC日记——忠诚 洛谷 P1816
  2. repcache实现memcached主从
  3. C#中的Decimal类型
  4. VS 2010下单元测试
  5. 定位表的数据块并且dump出来
  6. HDU-3719 二叉搜索树
  7. A题笔记(7)
  8. 磁盘IO单线程顺序写时最快的,如果多线程写,磁盘的磁头要不断重新寻址,所以写入速度反而会慢
  9. Performing Post-Build Event之类的编译错误
  10. SUID SGID
  11. linux中搭建solr集群出现org.apache.catalina.LifecycleException: Failed to initialize component ,解决办法
  12. linux下安装python3.6.4
  13. TCP的11种状态
  14. Java Spring Boot VS .NetCore (一)来一个简单的 Hello World
  15. python统计目录和目录下的文件,并写入excel表
  16. 查看windows到期时间
  17. UML和模式应用4:初始阶段(2)--需求科目之进化式需求
  18. vue项目中, 字段信息为空时不渲染,是真的不渲染吗
  19. week3编程作业: Logistic Regression中一些难点的解读
  20. java内存溢出xms xmx

热门文章

  1. SQL Server 日期格式化输出
  2. spring-security+hibernate4+quartz实现的心跳检测项目(转 收藏)
  3. linux 文本编辑器
  4. vfptr(2)
  5. CodeIgniter框架——nginx下的配置
  6. 【BZOJ2282】[Sdoi2011]消防 树形DP+双指针法+单调队列
  7. Linux 常用命令缩写及对应的
  8. 封装AFNetworking
  9. Kuratowski&#39;s and Wagner&#39;s theorems
  10. 数据库之MySQL(四)