繁体   English   中英

用 datediff 和 substring 计算分钟数

[英]Count the number of minutes with datediff and substring

我有这样的数据

availabilities
[{"starts_at":"09:00","ends_at":"17:00"}]

我在下面有查询,它有效

select COALESCE(availabilities,'Total')      as availabilities,
       SUM(DATEDIFF(minute,start_at,end_at)) as 'Total Available Hours in Minutes'
from (
    select cast(availabilities as NVARCHAR)             as availabilities,
           cast(SUBSTRING(availabilities,16,5) as time) as start_at,
           cast(SUBSTRING(availabilities,34,5) as time) as end_at
    from alfy.dbo.daily_availabilities
)x
GROUP by ROLLUP(availabilities);

结果

availabilities                                          Total Available Hours in Minutes
[{"starts_at":"09:00","ends_at":"17:00"}]                                            480

如果数据如下所示

availabilities
[{"starts_at":"10:00","ends_at":"13:30"},{"starts_at":"14:00","ends_at":"18:00"}]
[{"starts_at":"09:00","ends_at":"12:30"},{"starts_at":"13:00","ends_at":"15:30"},{"starts_at":"16:00","ends_at":"18:00"}]

如何计算两个或多个时间范围内的分钟数?

由于您有 JSON 数据使用OPENJSON (Transact-SQL)来解析它,例如:

create table dbo.daily_availabilities (
  id int,
  availabilities nvarchar(max) --JSON
);

insert dbo.daily_availabilities (id, availabilities) values
  (1, N'[{"starts_at":"09:00","ends_at":"17:00"}]'),
  (2, N'[{"starts_at":"10:00","ends_at":"13:30"},{"starts_at":"14:00","ends_at":"18:00"}]'),
  (3, N'[{"starts_at":"09:00","ends_at":"12:30"},{"starts_at":"13:00","ends_at":"15:30"},{"starts_at":"16:00","ends_at":"18:00"}]');

select id, sum(datediff(mi, starts_at, ends_at)) as total_minutes
from dbo.daily_availabilities
cross apply openjson(availabilities) with (
  starts_at time,
  ends_at time
) av
group by id
ID 总分钟数
1 480
2 450
3 480

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM