I have a table with columns score
and timestamp
. I need to select each row that score
is a new high, when sorted by timestamp
(bold rows):
score | timestamp |
---|---|
6 | 1 |
3 | 2 |
3 | 3 |
5 | 4 |
7 | 5 |
10 | 6 |
8 | 7 |
9 | 8 |
10 | 9 |
11 | 10 |
CodePudding user response:
select records
,min(Timestamp) as Timestamp
from (
select max(Score) over(order by timestamp) as records, Timestamp
from t
) t
group by records
records | Timestamp |
---|---|
6 | 1 |
7 | 5 |
10 | 6 |
11 | 10 |
CodePudding user response:
You may try the following (Supposing that timestamp is unique):
Select T.Score, T.Timestamp
From score_tbl T
Where NOT Exists(Select 1 From score_tbl D Where D.Timestamp < T.Timestamp And D.Score >= T.Score)
Order By T.Timestamp
See a demo.