gpt4 book ai didi

SQL (BigQuery) 每天分组运行时

转载 作者:行者123 更新时间:2023-12-01 23:43:25 25 4
gpt4 key购买 nike

我有以下数据,我想在 BigQuery 中每天按秒分组。
源表:

+--------------+---------------------+---------------------+| ComputerName | StartDatetime       | EndDatetime         |+--------------+---------------------+---------------------+| Computer1    | 2020-06-10T21:01:28 | 2020-06-10T21:20:19 |+--------------+---------------------+---------------------+| Computer1    | 2020-06-10T22:54:01 | 2020-06-11T05:21:48 |+--------------+---------------------+---------------------+| Computer2    | 2020-06-08T09:11:54 | 2020-06-10T11:36:27 |+--------------+---------------------+---------------------+

我希望能够通过以下方式可视化数据

+------------+--------------+------------------+| Date       | ComputerName | Runtime(Seconds) |+------------+--------------+------------------+| 2020-10-10 | Computer1    | 5089             |+------------+--------------+------------------+| 2020-10-11 | Computer1    | 19308            |+------------+--------------+------------------+| 2020-10-08 | Computer2    | 53285            |+------------+--------------+------------------+| 2020-10-09 | Computer2    | 86400            |+------------+--------------+------------------+| 2020-10-10 | Computer2    | 41787            |+------------+--------------+------------------+

我不太确定我应该如何处理这个问题。一些意见将不胜感激。

最佳答案

这是一个区间重叠问题。您可以通过将每个时间段分成不同的日子然后查看每一天的重叠来解决此问题:

with t as (
select 'Computer1' as computername, datetime '2020-06-10T21:01:28' as startdatetime, datetime '2020-06-10T21:20:19' as enddatetime union all
select 'Computer1' as computername, datetime '2020-06-10T22:54:01' as startdatetime, datetime '2020-06-11T05:21:48' as enddatetime union all
select 'Computer2' as computername, datetime '2020-06-08T09:11:54' as startdatetime, datetime '2020-06-10T11:36:27' as enddatetime
)
select dte, t.computername,
sum(case when enddatetime >= dte and
startdatetime < date_add(dte, interval 1 day)
then datetime_diff(least(date_add(dte, interval 1 day), enddatetime),
greatest(dte, startdatetime),
second)
end) as runtime_seconds
from (select t.*,
generate_date_array(date(t.startdatetime), date(t.enddatetime), interval 1 day) gda
from t
) t cross join
unnest(gda) dte
group by dte, t.computername;

关于SQL (BigQuery) 每天分组运行时,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64689140/

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