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

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

sql server如何分组编号

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

sql server如何分组编号

具体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

 

相关文章:

  • 2021-10-17
  • 2022-12-23
  • 2021-07-20
  • 2021-06-24
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2022-12-23
  • 2021-09-16
  • 2022-12-23
  • 2022-02-27
  • 2022-12-23
  • 2021-10-26
  • 2022-01-23
相关资源
相似解决方案