pgsql查询昨天到今天的每个小时时间
时间: 2024-03-20 14:38:52 浏览: 23
您可以使用 PostgreSQL 中的 generate_series 函数来生成指定的时间间隔序列,然后使用 date_trunc 函数将其舍入到小时级别,最后使用 GROUP BY 子句进行聚合。以下是一个示例查询:
```
SELECT
date_trunc('hour', generate_series) AS hour_start,
date_trunc('hour', generate_series + interval '1 hour') AS hour_end
FROM
generate_series(
current_date - interval '1 day',
current_date,
interval '1 hour'
)
AS generate_series;
```
这个查询将生成从昨天到今天每个小时的起始和结束时间。如果您需要在查询中使用这些时间数据,可以将其包装在子查询中,如下所示:
```
SELECT
hour_start,
hour_end,
COUNT(*)
FROM (
SELECT
date_trunc('hour', generate_series) AS hour_start,
date_trunc('hour', generate_series + interval '1 hour') AS hour_end
FROM
generate_series(
current_date - interval '1 day',
current_date,
interval '1 hour'
)
AS generate_series
)
AS hours
JOIN your_table
ON your_table.timestamp >= hours.hour_start
AND your_table.timestamp < hours.hour_end
GROUP BY hour_start, hour_end;
```
这个查询将计算每个小时内记录的数量,并将结果按小时分组。请注意,您需要将 "your_table" 替换为包含您的时间戳列的表的名称。
相关推荐
![pdf](https://img-home.csdnimg.cn/images/20210720083512.png)
![zip](https://img-home.csdnimg.cn/images/20210720083736.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)