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必填
【推荐】还在用 ECharts 开发大屏?试试这款永久免费的开源 BI 工具!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步