Hive系列 (六):Hive数据类型转换

Hive系列 (六):Hive数据类型转换hive 数据类型转换规则及转换原则 日期类型转换

Hive系列文章

Hadoop完全分布式搭建(腾讯云服务器+阿里云服务器)

Hive系列 (一):Hive搭建

Hive系列 (二):Hive基础知识

Hive系列 (三):Hive开窗函数详解

Hive系列 (四):自定义函数UDF UDTF UDAF

Hive系列 (五):Hive数据类型

Hive系列 (六):Hive数据类型转换

Hive系列 (七):Hive常用函数

Hive系列 (八):Hive中的explode 与 lateral view

Hive系列 (九):Hive数据存储

Hive系列 (十):Hive调优

数据类型转换

同其他语言一样,Hive也包含隐式转换显式转化

  1. Hive会对numeric类型的数据进行隐式转换。
  2. 任何整数类型都可以隐式地转换成一个范围更大的类型。
  3. TINYINT,SMALLINT,INT,BIGINT,FLOAT和STRING都可以隐式 地转换成DOUBLE;BOOLEAN类型不能转换为其他任何数据类型。
  4. 可以使用CAST操作显示进行数据类型转换,例如CAST(‘1’ AS INT)将把字符串’1’ 转换成整数1;如果强制类型转换失败,如执行CAST(‘X’ AS INT),表达式返回空值 NULL

Cast显示转换

可以用CAST来显式的将一个类型的数据转换成另一个数据类型,其语法为cast(value AS TYPE)

0: jdbc:hive2://master:10000> select stu_id,chinese from myhive.stu_scores where stu_id = 10001; OK +---------+----------+ | stu_id | math | +---------+----------+ | 10001 | 70.0 | +---------+----------+ 1 row selected (4.558 seconds) 0: jdbc:hive2://master:10000> select stu_id,cast(math as float) as math from myhive.stu_scores where stu_id = 10001; OK +---------+-------+ | stu_id | math | +---------+-------+ | 10001 | 70.0 | +---------+-------+ 1 row selected (4.105 seconds) 0: jdbc:hive2://master:10000>  # 这样math将会显示的转换成float。如果math是不能转换成float,这时候cast将会返回NULL 

注意事项:

  1. 如果将浮点型的数据转换成int类型的,内部操作是通过round()或者floor()函数来实现的,而不是通过cast实现。
  2. 对于binary类型的数据,只能将binary类型的数据转换成string类型。
  3. 只有binary类型数据是一个数字类型(a number),这时候你可以利用嵌套的cast操作
    select(cast(cast(a as string) as double)) from tb1 

数据类型转换表

boolean tinyint smallint int bigint float double decimal string varchar timestamp date binary
boolean true false false false false false false false false false false false false
tinyint false true true true true true true true true true false false false
smallint false false true true true true true true true true false false false
int false false false true true true true true true true false false false
bigint false false false false true true true true true true false false false
float false false false false false true true true true true false false false
double false false false false false false true true true true false false false
decimal false false false false false false false true true true false false false
string false false false false false false true true true true false false false
varchar false false false false false false true true true true false false false
timestamp false false false false false false false false true true true false false
date false false false false false false false false true true false true false
binary false false false false false false false false false false false false true

日期类型转换说明

有效的转换 结果
cast(date as date) 返回date类型
cast(timestamp as date) timestamp中的年/月/日的值是依赖与当地的时区,结果返回date类型
cast(string as date) 如果string是YYYY-MM-DD格式的,则相应的年/月/日的date类型的数据将会返回;但如果string不是YYYY-MM-DD格式的,结果则会返回NULL。
cast(date as timestamp) 基于当地的时区,生成一个对应date的年/月/日的时间戳值
cast(date as string) date所代表的年/月/日时间将会转换成YYYY-MM-DD的字符串

转换示例

日期与字符串转换

# cast(string as date) # 不是YYYY-MM-DD格式返回null 0: jdbc:hive2://master:10000> select cast('' as date); OK +-------+ | _c0 | +-------+ | NULL | +-------+ 1 row selected (2.135 seconds) 0: jdbc:hive2://master:10000> select cast('2021-08-25' as date); OK +-------------+ | _c0 | +-------------+ | 2021-08-25 | +-------------+ 1 row selected (2.167 seconds) # 日期转字符串 0: jdbc:hive2://master:10000> select cast(current_date() as string); OK +-------------+ | _c0 | +-------------+ | 2021-08-25 | +-------------+ 1 row selected (2.291 seconds) 0: jdbc:hive2://master:10000>  

时间戳与日期转换

# cast(timestamp as date) # 显示当前时间戳current_timestamp() 0: jdbc:hive2://master:10000> select current_timestamp(); OK +--------------------------+ | _c0 | +--------------------------+ | 2021-08-25 16:35:27.249 | +--------------------------+ 1 row selected (2.287 seconds) # 时间戳转日期 0: jdbc:hive2://master:10000> select cast(current_timestamp() as date); OK +-------------+ | _c0 | +-------------+ | 2021-08-25 | +-------------+ 1 row selected (2.399 seconds) # 日期转时间戳 0: jdbc:hive2://master:10000> select cast(current_date() as timestamp); OK +------------------------+ | _c0 | +------------------------+ | 2021-08-25 00:00:00.0 | +------------------------+ 1 row selected (2.325 seconds) 0: jdbc:hive2://master:10000> 
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/233134.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • rabbit mq exchange_exchange设置公司邮箱

    rabbit mq exchange_exchange设置公司邮箱上一篇,我们介绍了rabbimtmq的简单工作队列的使用方式,即生产者和消费者之间直接通过绑定相同的workqueue进行消息的发送和接收,如果业务逻辑比较简单,这样的方式也是可以用的,但在实际工作中,实际的业务场景远远比这个复杂,而且需要更加细粒度的对消息进行进行分发和接收,这就需要用到rabbitmq的另外一个组件exchange;顾名思义,exchange在rabbitmq中翻译为交换机…

    2022年10月3日
    2
  • 计算机代码1e1代表什么意思,热水器上显示E1是什么意思

    计算机代码1e1代表什么意思,热水器上显示E1是什么意思再好的产品也有可能会出现故障,如果家里的壁挂炉出现故障了,显示了一些字母代码,你知道这些字母代码是什么意思吗?又该采取什么措施去解决呢?下面小编总结了一些品牌壁挂炉的故障代码,供大家参考。威能壁挂炉威能燃气壁挂炉运行时吐过发生故障,显示屏上会出现一个故障代码,多个代码交替出现,则说明是同时发生了多个故障。威能壁挂炉故障代码含义解析:F.0含义:供水温度传感器(NTC)故障原因:NTC故障,…

    2022年5月30日
    35
  • 单片机应用基础知识_51单片机基础知识总结

    单片机应用基础知识_51单片机基础知识总结单片机——硬件基础知识宗旨:技术的学习是有限的,分享的精神是无限的。1、单片机内部资源STC89C52:8KFLASH、512字节RAM、32个IO口、3个定时器、1个UART、8个中断源(1)Flash(硬盘)——程序存储空间——擦写10万次,断电数据不丢失,读写速度慢(2)RAM(内存)——数据存储空间——断电数据丢失

    2025年10月3日
    5
  • webdriver 下载_WebBrowser

    webdriver 下载_WebBrowserChrome:http://chromedriver.storage.proxy.ustclug.org/index.html

    2026年1月27日
    5
  • 利用SecureCRTPortable远程连接虚拟机

    利用SecureCRTPortable远程连接虚拟机利用SecureCRTPortable远程连接虚拟机1.出现的问题​ 打开SecureCRTP之后,输入正确的ip地址却无法连接到虚拟机。​ 2.解决调试​ 1.通过windows的cmd去ping虚拟机,同样还是ping不通2.查看网络适配器中VMnet8(该网卡是作为虚拟机与本机交互的一个网卡)3.错误原因:网卡中的ip地址与虚拟机中的地址相同,网关与虚拟机不相同​ 更改网卡中的ip地址使得…

    2022年6月14日
    40
  • Ajax 模糊查询的简单实现[通俗易懂]

    Ajax 模糊查询的简单实现[通俗易懂]类似于百度的搜索引擎模糊查询功能,不过百度的模糊查询功能更强大,这里简单实现下.要实现模糊查询,首先要做的就是把SQL写好。话不多少,直接贴代码了!JSP页面:<%Stringpath=request.getContextPath();StringbasePath=request.getScheme()+"://"+request.getServerName()+":

    2022年5月29日
    121

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号