我在Impala中使用SQL来编写此查询.我正在尝试将以YYYYMMDD格式存储的日期字符串转换为日期格式,以便运行如下查询:
SELECT datadate,
session_info
FROM database
WHERE datadate >= NOW() - INTERVAL 5 DAY
ORDER BY datadate DESC;
由于> = NOW() – INTERVAL 5 DAY代码不能与YYYYMMDD字符串一起使用,我想找到一种方法将其转换为可用于此类查询的日期格式.我的想法是它应该看起来像这样(基于关于其他SQL查询编辑器的类似问题),但它在Impala中不起作用:
SELECT datadate,
session_info,
convert(datetime, '20141008', 102) AS session_date
FROM database
WHERE session_date >= NOW() - INTERVAL 5 DAY
ORDER BY session_date DESC;
任何人都知道如何在Impala中做到这一点?
编辑:
我终于找到了解决问题的有效方法.使用CAST或CONVERT配置的任何尝试都不会在Impala中起作用,但是下面的查询解决了问题并且完全可操作,允许对包含字符串值的列执行日期数学运算:
SELECT datadate,
session_info
FROM database
WHERE datadate >= from_unixtime(unix_timestamp(now() - interval 5 days), 'yyyyMMdd')
GROUP BY datadate
ORDER BY datadate DESC;
版权声明:本文为weixin_31258847原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。