[英]How to aggregate rows on BigQuery
我需要在我的数据集中对不同年份进行分组,以便我可以看到每年 login_log_id 的总数(BigQuery)
SELECT login_log_id,
DATE(login_time) as login_date,
EXTRACT(YEAR FROM login_time) as login_year,
TIME(login_time) as login_time,
FROM `steel-time-347714.flex.logs`
GROUP BY login_log_id
我想进行分组,以便查看不同年份生成的 login_log_id 总数。
我的专栏是login_log_id
, login_time
我收到以下错误:-
SELECT 列表表达式引用列 login_time 既不分组也不聚合在 [2:6]
该错误是因为您在 select 中引用的每一列都需要聚合或位于GROUP BY
中。
如果您想要按年份的总登录次数,您可以执行以下操作:
SELECT
EXTRACT(YEAR FROM login_time) as login_year,
COUNT(1) as total_logins,
COUNT(DISTINCT login_log_id) as total_unique_logins
FROM `steel-time-347714.flex.logs`
GROUP BY login_year
但是,如果您希望按 login_log_id 和年份计算总数:
SELECT
login_log_id,
EXTRACT(YEAR FROM login_time) as login_year,
COUNT(1) as total_logins
FROM `steel-time-347714.flex.logs`
GROUP BY login_log_id, login_year
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.