简体   繁体   中英

Count the number of minutes with datediff and substring

I have data like this

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

I have query below and it works

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);

Result

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

How if the data like below

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"}]

How to count the number of minutes over two or more time ranges?

Since you have JSON data use OPENJSON (Transact-SQL) to parse it, eg:

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 total_minutes
1 480
2 450
3 480

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

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