Om jag förstår det rätt vill du ha det sista värdet som är ett av de fyra som du anger (dvs inte 'NONE'
). Fönsterfunktioner är förmodligen den enklaste lösningen:
select t.*
from (select t.*,
first_value(value) over (partition by uaid order by id desc) as current_value
from t
) t
where risk_factor <> 'NONE';