Bạn có thể tổng hợp số lượng hàng cố định bằng cách sử dụng row_number()
và số học:
select min(date),
(array_agg(bid order by seqnum asc))[1] as open,
(array_agg(bid order by seqnum desc))[1] as close,
min(bid) as min_bid, max(bid) as max_bid
from (select t.*, row_number() over (order by date) as seqnum
from ticks t
) t
group by floor((seqnum - 1) / 500);
Điều này sử dụng "hack" để lấy open
và close
- bằng cách sử dụng mảng.