Hive中CAST()函数用法

Cast(字段名 as 转换的类型 ),其中类型可以为:

  • CHAR[(N)] 字符型
  • DATE 日期型
  • DATETIME 日期和时间型
  • DECIMAL float型
  • SIGNED int
  • TIME 时间型

例如表table1
 

-- date
-- 2015-11-03 15:31:26

select cast(date as signed) as date from table1; 


-- 结果如下:
date
20151103153126


select cast(date as char) as date from table1;

-- 结果如下:
date
2015-11-03 15:31:26

select cast(date as datetime) as date from table1;
-- 结果如下:
date
2015-11-03 15:31:26


select cast(date as date) as date from table1;

--结果如下:
date
2015-11-03


select cast(date as time) as date from table1;
-- 结果如下:
date
15:31:26


这里date对应日期,time对应时间


 

  • 4
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
HiveCAST函数用于将一个数据类型转换为另一个数据类型。下面是Hive CAST函数的源代码: ```java public class GenericUDFToChar extends GenericUDF { private transient ObjectInspector[] argumentOIs; private transient PrimitiveObjectInspector inputOI; private transient PrimitiveObjectInspector outputOI; private transient FormatDateTime formatter; @Override public ObjectInspector initialize(ObjectInspector[] arguments) throws UDFArgumentException { if (arguments.length != 2) { throw new UDFArgumentLengthException("CAST() takes exactly two arguments"); } inputOI = HiveUtils.asPrimitiveObjectInspector(arguments[0]); outputOI = HiveUtils.asPrimitiveObjectInspector(arguments[1]); formatter = new FormatDateTime(); argumentOIs = arguments; return outputOI; } @Override public Object evaluate(DeferredObject[] arguments) throws HiveException { if (arguments[0].get() == null) { return null; } String input = inputOI.getPrimitiveJavaObject(arguments[0].get()).toString(); String outputTypeName = outputOI.getTypeName().toLowerCase(); if (outputTypeName.startsWith("char")) { int outputLength = Integer.parseInt(outputTypeName.substring(4)); return formatter.formatChar(input, outputLength); } else if (outputTypeName.startsWith("varchar")) { int outputLength = Integer.parseInt(outputTypeName.substring(7)); return formatter.formatVarChar(input, outputLength); } else { throw new HiveException("CAST(): unsupported conversion from " + inputOI.getTypeName() + " to " + outputTypeName); } } @Override public String getDisplayString(String[] children) { return "cast(" + children[0] + " as " + children[1] + ")"; } } ``` 这个源代码实现了将一个数据类型转换为另一个数据类型的功能,支持将输入数据类型转换为char或varchar类型的输出数据类型。在实现过程,使用了Java的ObjectInspector类来获取输入和输出数据类型的相关信息,并使用FormatDateTime类来格式化输出的数据。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

香山上的麻雀1008

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值