本文主要是介绍postgresql查询每组的前N条记录,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
方式
ROW_NUMBER() OVER (PARTITION BY "字段1","字段2..." ORDER BY 排序字段1 desc ,排序字段2 DESC) AS row_id
例如:
select * from (select *,ROW_NUMBER() OVER (PARTITION BY t.src_ip, t.event_name, t.threats ) AS row_id FROM t_log t) t where t.row_id <=5
解析:
这里查询的是t_log表的整张数据,通过 t.src_ip, t.event_name, t.threats 分组;
同时会生成一个分组的row_id,通过t.row_id <=5可以限制每个分组5条数据;
参考文章:
【postgresql 基础入门】多表联合查询 join与union 并,交,差等集合操作,两者的区别之处 - 范斯猫
postgreSQL 操作 教程 - 范斯猫
postgresql表操作 - 范斯猫
这篇关于postgresql查询每组的前N条记录的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!