SQL排序后将序号填入指定字段

来源:互联网 发布:排序算法中空间复杂度 编辑:程序博客网 时间:2024/05/31 05:28

1、显示行号

    如果数据没有删除的情况下主键与行号是一致的,但在删除某些数据,行号就与主键不一致了,这时需要查询行号就需要用新的方法,在SQL Server2005之前,需要使用临时表,但在SQL Server2005中,使用ROW_NUMBER()非常方便。

以下是一个查询语句,意思是按照cid将数据排序,然后将排序后的序号填入新建的字段rowNum。

select row_number() over (order by cid) as rowNum,* from t_gene

查询结果:

wKiom1gxUd2ie3rqAABE1BrDH7c447.jpg


2.运用

    以下是本文需要达到的目的,即排序后,将排序后的序号更新到指定字段。

with ts as(select row_number() over (order by clccode) as rn,* from t_gene)update tsset  cdkxh=rn

运行结果:

    未排序前。此时可以看到字段cdkxh大小参差不齐

select * from t_gene

wKioL1gxUyuBdsSjAABsuyaUjMg917.jpg

    排序后,将临时字段rn的序号更新到字段cdkxh

wKiom1gxVBCyP-R_AABnBDwayGU351.jpg



本文出自 “世界都一样” 博客,请务必保留此出处http://970076933.blog.51cto.com/9767314/1874767

0 0
原创粉丝点击