sql server如何分组编号

Posted Kevin-kw

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了sql server如何分组编号相关的知识,希望对你有一定的参考价值。

我们在生产实践中经常会有这样的需求:分组编号。

如下有一个城市区域表region:

我们需要对上表region按city分组,对region进行排序,得到如下结果:

具体sql如下:

1 select city,region, 
2 right(\'100\'+row_number()over(partition by city order by region),2) as region_no 
3 from region

此方法主要是运用row_number()开窗函数通过对city进行分组后,再对region进行排序(默认按首字母拼音排序),最终得到我们想要的结果。

当然,还有一种方法同样可以实现:

select city,region,
region_no=right(100+(select count(1)+1 from region where city=a.city and region<a.region),2)
from region a

 

以上是关于sql server如何分组编号的主要内容,如果未能解决你的问题,请参考以下文章

sqlserver用group by分组了,但是怎么才能给每一组数据按照从小到大编号呢

SQL Server 2012按倒序存储“分组统计”结果的临时表到新建表

缺少 SQL SERVER 2014 代码片段

SQL Server:分组重复行集

如何更新账单编号栏?或在 sql server 的列中按顺序排列

如何从 SQL Server 中的日期获取月份编号(不是月份名称)?