sql 实现取表中相同id时间最大的一行 利用distinct on

数据表是这样的

select * from water_level_records  m where (
        select count(*) from water_level_records n where m.device_id = n.device_id and m.record_time < n.record_time
        ) < 1

这个sql的逻辑是把一个表当做两个表关联来使用,当满足m的记录时间小于n的记录时间的数量<1 即只有一个相等时返回,即是时间的最大值, 如果为<2 则是为前两大的值,这里以device_id为唯一关联

一种更搞笑的方法如下

SELECT DISTINCT on (device_id ) device_id  ,record_time from water_level_records order by device_id , record_time desc 

这里DISTINCT on的用法和效果与DISTINCT不同,如果这里为DISTINCT 则 device_id   record_tiem 这两列有一列不同就满足唯一性。而distinct on的效果为不管后面跟了几列,必须保持device_id的唯一性 

这里加上order by record_time desc 的效果为只取时间最大的一项。另注意DISTINCT on (device_id ) 如果加order by 的话 order by device_id必填

posted @ 2019-06-17 21:49  大老虎打老虎  阅读(5089)  评论(0编辑  收藏  举报