gpt4 book ai didi

sql - 每小时数据透视表

转载 作者:行者123 更新时间:2023-11-29 11:59:50 24 4
gpt4 key购买 nike

我想显示以下给定记录的数据透视表:

我有一个名为 fooo 的表,其中包含两列:

create table fooo (
cola varchar(5),
colb time
);

插入一些记录:

insert into fooo values
('a','10:00:00'), ('a','10:30:00'), ('b','20:00:00'), ('c','13:00:00')
, ('d','01:00:00'), ('e','10:10:00'), ('f','02:01:00'), ('g','02:20:00')
, ('h','04:00:00'), ('i','05:00:00'), ('j','06:00:00'), ('k','07:00:00')
, ('l','08:00:00'), ('m','09:00:00'), ('n','22:00:00'), ('o','23:00:00');

预期的输出应该类似于以下格式:

预期输出:

cola  01  02  03  04  05  06  07  08  09  10  11  12  13  14  15  16  17  18  19  20  21  22  23    
-------------------------------------------------------------------------------------------------
a 2
b 1
c 1
d 1
e 1
f 1
g 1
h 1
i 1
j 1
k 1
l 1
m 1
n 1
o 1

最佳答案

SELECT * FROM crosstab(
'SELECT cola, EXTRACT(HOUR from colb) AS h, count(*) AS ct
FROM fooo
GROUP BY 1, 2
ORDER BY 1, 2'

,'SELECT g::float8 FROM generate_series(0,23) g'
) AS ct (cola text
, h00 int, h01 int, h02 int, h03 int, h04 int, h05 int
, h06 int, h07 int, h08 int, h09 int, h10 int, h11 int
, h12 int, h13 int, h14 int, h15 int, h16 int, h17 int
, h18 int, h19 int, h20 int, h21 int, h22 int, h23 int);

旁白:
您忘记了 0/24 小时。
使用带有前导字符的列名来避免使用双引号。

详细信息:

关于sql - 每小时数据透视表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28804776/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com