1.分组一般用group by。但是group by也有局限性,就在以某个字段分组时,再查找其他字段,就得使用分组函数。现在分享一下另一种分组排序:row_number() over()
2.语法
row_number() over(partition by col1 order by col2)表示根据col1分组,在分组内部根据col2排序,而此函数计算的值就表示每组内部排序后的顺序编号(组内连续的唯一的)。
与rownum的区别在于:使用rownum进行排序的时候是先对结果集加入伪劣rownum然后再进行排序,而此函数在包含排序从句后是先排序再计算行号码。row_number()和rownum差不多,功能更强一点(可以在各个分组内从1开始排序)
3.示例
select t.* from (
select t.*,row_number() over(partition by t.unit order by t.id) rn from BOM_MATE_INFO t
)t where t.rn=1
效果:
这示例就是以unit来分组。