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)