首页 > 解决方案 > 将日期时间条目放入存储桶的 SQL 命令

问题描述

我有一个表结构如下:

timestamp
2020-03-10 04:05:44.000000
2020-03-10 04:05:44.000000
2020-03-10 04:05:44.000000
2020-03-10 04:05:44.000000
2020-03-10 07:07:44.000000
2020-03-10 07:07:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000
2020-03-10 13:17:44.000000

每天只有三个时间戳(时间可能不同,但总是三个)。我想要的是另一列,它告诉我哪个时间戳是第一个、第二个和第三个,即产生如下输出:

timestamp                   timestamp_order
2020-03-10 04:05:44.000000  1
2020-03-10 04:05:44.000000  1
2020-03-10 04:05:44.000000  1
2020-03-10 04:05:44.000000  1
2020-03-10 07:07:44.000000  2
2020-03-10 07:07:44.000000  2
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3
2020-03-10 13:17:44.000000  3

三个存储桶之间的条目数量可能不同。我已经尝试了一些 RANK() 或 NTILE() 函数,但无法获得正确的输出,因为它给我的数字太高(排名给我 1,1,1,1,5,5,...)或假设大小相同的桶。

谢谢!

标签: sqlrank

解决方案


不确定它是否适用于所有 dbms(至少在 Postgres 中有效),但您可以尝试:

SELECT 
    timestamp, 
    DENSE_RANK() OVER(PATITION BY date_trunc('day', timestamp) 
                       ORDER BY timestamp) as timestamp_order
FROM table

date_trunc从您的时间戳中提取日期,排名为您提供


推荐阅读