码迷,mamicode.com
首页 > 数据库 > 详细

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

时间:2016-11-21 02:29:09      阅读:193      评论:0      收藏:0      [点我收藏+]

标签:sql 、排序、row_number

1、显示行号

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

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

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

查询结果:

技术分享


2.运用

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

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

运行结果:

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

select * from t_gene

技术分享

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

技术分享



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

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

标签:sql 、排序、row_number

原文地址:http://970076933.blog.51cto.com/9767314/1874767

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!