mysql datetime hive_Hive - 仅按日期时间列分组(Hive - Group by datetime column to date only)

Hive - 仅按日期时间列分组(Hive - Group by datetime column to date only)

在我的表eventtime列看来,

2017-03-25T03:18:00001Z

2017-03-25T05:21:00013Z

我想按事件时间分组,仅限日期。

喜欢

2017-03-18, 2017-03-21

In my table eventtime column looks like,

2017-03-25T03:18:00001Z

2017-03-25T05:21:00013Z

I want to group by eventtime with date only.

Like

2017-03-18, 2017-03-21

原文:https://stackoverflow.com/questions/43037762

更新时间:2020-01-24 10:01

最满意答案

在GROUP BY和SELECT子句中使用它。

cast (from_iso8601_timestamp(eventtime) as date)

Use it both in the GROUP BY and the SELECT clauses.

cast (from_iso8601_timestamp(eventtime) as date)

2017-03-27

相关问答

基本上进行查找请按照以下步骤操作, 你必须创建一个custom User Defined function(UDF) ,它基本上可以查找工作,这意味着你必须在内部创建一个Java程序来查找,jar它并将它添加到Hive,如下所示: 添加JAR /home/ubuntu/lookup.jar 然后,您必须添加包含keyvalue对的查找文件,如下所示: 添加文件/ home / ubuntu / lookupA; 然后,您必须创建一个临时查找功能,如 CREATE TEMPORARY FUNCTIO

...

ROW_NUMBER select id,zip,Action,content,duration,OS

from (select *

,row_number() over

(

partition by id,zip

order by time desc

) as rn

fro

...

将日期时间转换为日期,然后使用以下语法将GROUP TIME设置为: SELECT SUM(foo), DATE(mydate) FROM a_table GROUP BY DATE(a_table.mydate);

或者你可以GROUP BY别名为@ orlandu63建议: SELECT SUM(foo), DATE(mydate) DateOnly FROM a_table GROUP BY DateOnly;

虽然我认为这不会对性能产生任何影响,但这是一个更清晰的一点。 Cast th

...

使用LEFT JOIN可以完成相同的功能: SELECT a.ID

FROM

(

SELECT DISTINCT ID

FROM my_table

WHERE date = '2016-07-14'

)a

LEFT JOIN (

SELECT DISTINCT ID

FROM my_table

...

为什么在可以在其上创建外部表格时移动文件? LOAD DATA INPATH只是将文件(HDFS元数据操作)“按原样”移动到表格的位置。 为什么在明确约会时将分区列定义为字符串? CREATE EXTERNAL TABLE URL ... PARTITIONED BY(dt DATE) ...

你为什么试图使用非ISO格式(yyyy.MM.dd)? ISO日期格式是yyyy-MM-dd 由于分区信息似乎不是数据的一部分,因此您有3个选项: 1。 使用常量(不允许表达式,包括函数),例如 LOAD

...

转换为unix时间戳格式,然后转换回字符串。 from_unixtime(unix_timestamp('20160921091213', 'yyyyMMddHHmmss'),'yyyy-MM-dd HH:mm:ss')

结果: 2016-09-21 21:12:13 convert to unix timestamp format and then convert back to string. from_unixtime(unix_timestamp('20160921091213', 'y

...

注意:您不能将多于1列设置为CURRENT_TIMESTAMP 。 这样,你不能在一列中设置CURRENT_TIMESTAMP SQL: CREATE TABLE IF NOT EXISTS `hive` (

`id` int(11) NOT NULL,

`name` varchar(255) COLLATE utf8_unicode_ci DEFAULT NULL,

`age` int(11) DEFAULT '0',

`datecreated` timestamp NULL D

...

我自己用一个解决方法解决了这个问题: 对于Date类型,您可以使用hive COALESCE函数,如下所示: COALESCE(nt.assess_dt, cast('9999-01-01' as date))

以上答案可以解释为: 找到nt.assess_dt (这是一个date类型列); 如果为null获取COALESCE函数中的下一个值; 这是上例中的非空值,因此将返回。 请注意,它与NVL略有不同,其中COALESCE返回的值必须属于同一类型。 因此,在上面的例子中, COALESCE不

...

两个查询都使用sqlContext.sql ("select ..."); select a,b

,collect_list(array(c,d,e,f,g))

from abc

group by a,b

;

+-----+-----+----------------------------------------------------------------------------------------------+

| aa |

...

在GROUP BY和SELECT子句中使用它。 cast (from_iso8601_timestamp(eventtime) as date)

Use it both in the GROUP BY and the SELECT clauses. cast (from_iso8601_timestamp(eventtime) as date)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值