Ho una tabella che rappresenta l'utilizzo di un prodotto, un po 'come un registro. L'utilizzo del prodotto viene registrato in più timestamp, voglio rappresentare gli stessi dati utilizzando intervalli di tempo.Comprimi più righe con data e ora contigue
Ecco come si presenta (PostgreSQL 9.1):
userid | timestamp | product
-------------------------------------
001 | 2012-04-23 9:12:05 | foo
001 | 2012-04-23 9:12:07 | foo
001 | 2012-04-23 9:12:09 | foo
001 | 2012-04-23 9:12:11 | barbaz
001 | 2012-04-23 9:12:13 | barbaz
001 | 2012-04-23 9:15:00 | barbaz
001 | 2012-04-23 9:15:01 | barbaz
002 | 2012-04-24 3:41:01 | foo
002 | 2012-04-24 3:41:03 | foo
voglio crollare le righe il cui tempo di differenza con la precedente esecuzione è inferiore a un delta (diciamo: due secondi), e ottenere il tempo e l'ora di fine cominciare, in questo modo:
userid | begin | end | product
----------------------------------------------------------
001 | 2012-04-23 9:12:05 | 2012-04-23 9:12:09 | foo
001 | 2012-04-23 9:12:11 | 2012-04-23 9:12:13 | barbaz
001 | 2012-04-23 9:15:00 | 2012-04-23 9:15:01 | barbaz
002 | 2012-04-24 3:41:01 | 2012-04-24 3:41:03 | foo
si prega di notare che l'utilizzo consecutivo di uno stesso prodotto è suddiviso in due righe se il loro utilizzo è più di del ta (2 secondi, in questo esempio) a parte.
create table t (userid int, timestamp timestamp, product text);
insert into t (userid, timestamp, product) values
(001, '2012-04-23 9:12:05', 'foo'),
(001, '2012-04-23 9:12:07', 'foo'),
(001, '2012-04-23 9:12:09', 'foo'),
(001, '2012-04-23 9:12:11', 'barbaz'),
(001, '2012-04-23 9:12:13', 'barbaz'),
(001, '2012-04-23 9:15:00', 'barbaz'),
(001, '2012-04-23 9:15:01', 'barbaz'),
(002, '2012-04-24 3:41:01', 'foo'),
(002, '2012-04-24 3:41:03', 'foo')
;
Questo è ... bello! Funziona esattamente come previsto, grazie! –