数据表是这样的
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必填