Hive基本数据类型
Hive支持的基本数据类型有:
TINKYINT
SMALLINT
INT
BIGINT
BOOLEAN
FLOAT
DOUBLE
STRING
TIMESTAMP
Hive集合数据类型
STRUCT
MAP
ARRAY
Hive数据类型转换
hive执行隐形转换,比如查询一张表的某个字段SMALLINT类型的数据,插入另一张表的INT类型的字段,那么这个过程是可以隐式转换的,不需要我们自己转换,但INT类型不能隐式转换程SMALLINT。即范围小的可以转换为范围大的。
Hive官方文档给出了隐式转换的规则:

Hive自动类型转换
参数hive.metastore.disallow.incompatible.col.type.changes默认为false,如果设置为true,则类型会按根据上表,如果转换类型是允许的,则数据会正常显示,否则显示为NULL。
Hive手动强制数据类型转换
通过CAST函数,可以实现类型转换。
今天之前遇到一种情况,数据类型定义的字符串,实际数据存储的是数字,排序的时候按这个字段排序,则用的是字符序列,因此就会造成9,81,7,34,这种排序结果。
这是通过CAST(‘column’ as ‘INT’)先转换为INT类型,再排序就可以得到正确结果。
注意: 浮点型数据转换为整型,用的是round()或者floor()实现
更多类型转换操作可以参考官方文档:https://cwiki.apache.org/confluence/display/Hive/LanguageManual+Types
本文介绍了Hive的各种数据类型,包括基本数据类型如TINYINT、STRING和TIMESTAMP,以及集合数据类型如STRUCT、MAP和ARRAY。文章还详细讨论了Hive的数据类型转换,包括自动类型转换和手动强制转换,特别提到了隐式转换的规则和如何使用CAST函数进行转换。对于实际遇到的问题,如字符串数据排序错误,可以通过将字符串转换为INT类型来解决。
2119

被折叠的 条评论
为什么被折叠?



