impala保存时间类型timestamp---NanoTimeUtils根据JdateTime生成nanotime

在Impala中,时间字段以int96格式存储,需将常规时间如2017-05-23 11:59:43.345717转换为timestamp。此过程涉及Julian day,通过JdateTime生成nanotime,再转为Binary存储在HDFS。NanoTimeUtils用于根据JdateTime生成nanotime,注意转换时要考虑时区差异。
摘要由CSDN通过智能技术生成

impala中时间字段采用int96保存,常规时间如:2017-05-23 11:59:43.345717要保存为timestamp类型,则需要经过转换才能使用。采用Julian day来格式化时间,利用JdateTime生成nanotime然后转换为Binary保存到hdfs.NanoTimeUtils根据JdateTime生成nanotime

注意时区:不同时区生成的结果不同

/**
 * 创建日期:2017-8-4
 * 包路径:org.meter.parquet.NanoTimeUtils.java
 * 创建者:meter
 * 描述:
 * 版权:copyright@2017 by meter !
 */
package org.meter.parquet;
import java.sql.Timestamp;
import java.util.Calendar;
import java.util.TimeZone;

import org.apache.parquet.example.data.simple.NanoTime;


import jodd.datetime.JDateTime;
/**
 * @author meter 
 * 文件名:NanoTimeUtils
 * @描述:NanoTime工具,用于保存parquet文件timestamp类型字段
 */
public class NanoTimeUtils {

	static final long NANOS_PER_SECOND = 1000000000;
	static final long SECONDS_PER_MINUTE = 60;
	static final long MINUTES_PER_HOUR = 60;

	private static final ThreadLocal<Calendar> parquetTsCalendar = new ThreadLocal<Calendar>();

	private static Calendar getCalendar() {
		// Calendar.getInstance calculates the current-time needlessly, so cache
		// an instance.
		if (parquetTsCalendar.get() == null) {
			parquetTsCalendar.set(Calendar.getInstance(TimeZone
					.getTimeZone("Asia/Shanghai")));
		}
		return parquetTsCalendar.get();
	}

	public static NanoTime getNanoTime(Timestamp ts) {

		Calendar calendar = getCalendar();
		calendar.setTime(ts);
		JDateTime jDateTime = new JDateTime(calendar.get(Calendar.YEAR),
				calendar.get(Calendar.MONTH) + 1, // java calendar index
													// starting at 1
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值