巧用 ROW_NUMBER() 生成不重复的唯一排序码,按客户的需要任意排序数据

本文介绍了一种利用SQL Server的ROW_NUMBER()函数为大量新闻数据批量生成唯一排序码的方法,并提供了一个C#示例,展示了如何通过编程实现新闻排序。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近项目里遇到这样的一个小技术问题,新闻可以任意按客户的需要进行排序,需要实现的效果图如下:

由于各种类别输入了蛮多测试信息,有几百条数据,一个个把排序码都生成也很麻烦,看能否没有什么好办法能生成不重复的,唯一排序码?达到如下效果?

总不可能人工的一个个输入吧? 也没那个耐心的,还是想想有什么好办法吧?

 

其实很快就想到了 ROW_NUMBER() 功能,用这个,应该是可行的,折腾了一小会儿,这个SQL语句就写好了,给大家分享一下,有需要的朋友们可以直接拿过来就可以用了,虽然也没什么难的,但是自己写总会折腾一会儿,直接复制过去修改一下,省心省事一些。

 

1  UPDATE BASE_NEWS
2     SET SortCode  =  NEWS.SortCode
3   FROM (SELECT ROW_NUMBER() OVER (ORDER BY CreateDate DESC)  +   10000000  AS SortCode
4                , Id
5           FROM BASE_NEWS) AS NEWS
6  WHERE NEWS.Id  =  BASE_NEWS.Id

 

此文虽然是过于基础了一些,但是往往基础的东西,大家日常生活里需要得更多,希望能对需要的人起点儿参考作用,可以COPY一下就可以用了. 

若有谁可以写得更好,也可以贴出来分享一下。

 

四个按钮中的代码实现可以参考一下

 

代码
 1           #region  private void SetSort(string function, int index) 设置排序顺序
 2           ///   <summary>
 3           ///  设置排序顺序
 4           ///   </summary>
 5           ///   <param name="function"> 排序动作 </param>
 6           ///   <param name="index"> 索引 </param>
 7           private   void  SetSort( string  function,  int  index)
 8          {
 9               string  id  =   this .gridView.DataKeys[index].Value.ToString();
10               string  targetId  =   string .Empty;
11               try
12              {
13                   this .DbHelper.Open();
14                   //  判断编辑权限
15                   //  this.CheckPermission(this.CategoryId, OperationCode.Edit);
16                   switch  (function)
17                  {
18                       case  BaseDbSortLogic.CommandSetTop:
19                           if  (index  >   0 )
20                          {
21                              BaseDbSortLogic.SetTop( this .DbHelper, ProjectTable.TableName, id);
22                               this .gridView.SelectedIndex  =   0 ;
23                          }
24                           break ;
25                       case  BaseDbSortLogic.CommandSetUp:
26                           if  (index  >   0 )
27                          {
28                              targetId  =   this .gridView.DataKeys[index  -   1 ].Value.ToString();
29                               this .gridView.SelectedIndex  =  index  -   1 ;
30                              BaseDbSortLogic.Swap( this .DbHelper, ProjectTable.TableName, id, targetId);
31                          }
32                           break ;
33                       case  BaseDbSortLogic.CommandSetDown:
34                           if  ((index  +   2 <   this .gridView.Rows.Count)
35                          {
36                              targetId  =   this .gridView.DataKeys[index  +   1 ].Value.ToString();
37                               this .gridView.SelectedIndex  =  index  +   1 ;
38                              BaseDbSortLogic.Swap( this .DbHelper, ProjectTable.TableName, id, targetId);
39                          }
40                           break ;
41                       case  BaseDbSortLogic.CommandSetBottom:
42                           if  ((index  +   2 <   this .gridView.Rows.Count)
43                          {
44                              BaseDbSortLogic.SetBottom( this .DbHelper, ProjectTable.TableName, id);
45                               this .gridView.SelectedIndex  =   this .gridView.Rows.Count  -   2 ;
46                          }
47                           break ;
48                  }
49                   //  获取列表
50                   this .DoSearch();
51              }
52               catch  (Exception ex)
53              {
54                   this .LogException(ex);
55                   throw  ex;
56              }
57               finally
58              {
59                   this .DbHelper.Close();
60              }
61          }
62           #endregion

 

 

 

将权限管理、工作流管理做到我能力的极致,一个人只能做好那么很少的几件事情。

posted on 2010-09-28 14:39 吉日嘎拉 不仅权通用权限 阅读(2672) 评论(31) 编辑 收藏

#1楼   回复  引用  查看     先顶再看o(∩_∩)o...

2010-09-28 14:44 | cnwei       

#2楼[楼主]  回复 引用 查看   

@cnwei
热烈欢迎,很简单的一个东东。

#3楼  回复 引用 查看   

思想很好,学习了,thanks
2010-09-28 14:58 | 寻自己       

#4楼  回复 引用 查看   

2010-09-28 15:14 | 小情       

#5楼  回复 引用 查看   

i have ever meet the problem before
2010-09-28 15:45 | 满晨晨       

#6楼  回复 引用 查看   

为什么不用 Sequence ?用 Sequence 不是更好
2010-09-28 16:00 | Jeffery You       

#7楼  回复 引用 查看   

支持
2010-09-28 16:08 | 异乡风铃       

#8楼[楼主]  回复 引用 查看   

@Jeffery You
sqlserver 有这个东西吗?

#9楼  回复 引用 查看   

改一条新闻的次序,还得把整个表的序列重新更新一次?
2010-09-28 16:54 | taia       

#10楼  回复 引用 查看   

呵呵,我还以为是 Oracle!不好意思。
不过,你也没说这是 SQL Server 啊,从文章中我也没看出来,而且 ROW_NUMBER 第一反应就是 Oracle,SQL Server 是后来才有的。
2010-09-28 16:56 | Jeffery You       

#11楼[楼主]  回复 引用 查看   

@taia

主要是有一大堆人工输入的测试数据在的

#12楼  回复 引用   

太基础了!
2010-09-28 18:00 | Fine1[未注册用户]

#13楼[楼主]  回复 引用 查看   

若是不太基础了,你也看不出是太基础了,呵呵。
引用Fine1:太基础了!

#14楼  回复 引用 查看   

以前排序都是直接使用datetime,目前好像没有这种需求了。
2010-09-28 20:33 | lcs-帅       

#15楼  回复 引用 查看   

UPDATE BASE_NEWS
SET SortCode = NEWS.SortCode
FROM (SELECT ROW_NUMBER() OVER(ORDER BY CreateDate DESC) + 10000000 AS SortCode
, Id,CreateDate
FROM BASE_NEWS) AS NEWS
WHERE NEWS.Id = BASE_NEWS.Id

楼主,我能看到这段SQL是在干什么,意思是说,我能看懂“FROM (SELECT ROW_NUMBER() OVER(ORDER BY CreateDate DESC) + 10000000 AS SortCode
, Id,CreateDate
FROM BASE_NEWS) AS NEWS”是在生成临时表。但一般的更新语句都是update tableName set fieldName=value where的形式,但在set和where之间冒出一个from子句出来,这种写法还是第一次看到。
2010-09-28 22:29 | Jeffrey.Liang       

#16楼[楼主]  回复 引用 查看   

@Jeffrey.Liang
你说到点子上了,技术就体现在 FROM 而且是虚拟的表上。
小子洞察力很强的嘛

#17楼  回复 引用 查看   

用(当前ID-最小id)+100000
2010-09-29 08:38 | ugvanxk       

#18楼  回复 引用 查看   

吉日兄,顶一个,基础但实用

#19楼  回复 引用 查看   

我操,我想死。
2010-09-29 08:58 | 鱼蛋儿       

#20楼  回复 引用 查看   

SQL 语句我能理解,可是这个SQL语句怎么解决客户自定义排序我没怎么看明白, 我看顺序是上移一个,下移一个或是到顶或是到尾是吧?
2010-09-29 09:04 | 随处走走       

#21楼[楼主]  回复 引用 查看   

@随处走走
置顶、上移、下移、置底

#22楼  回复 引用 查看   

有没有比较好的方法对换两条记录的排序号
2010-09-29 09:52 | 超级奶崽       

#23楼  回复 引用 查看   

我用一个时间字段来排序的
2010-09-29 10:21 | 軒轅劍       

#24楼  回复 引用 查看   

哎哟,不错哦!!!
2010-09-29 10:42 | cherry .Net       

#25楼  回复 引用 查看   

@吉日嘎拉 不仅权限管理
。。。我能看懂那四个图标, 我是没看懂这四个图标怎么和你提供的SQL语句关联
2010-09-29 10:59 | 随处走走       

#26楼[楼主]  回复 引用 查看   

那4个图标对应的代码,就是C#写的了,不是sql语句了,我把代码也贴上,给大家一个参考好了。

引用随处走走:
@吉日嘎拉 不仅权限管理
。。。我能看懂那四个图标, 我是没看懂这四个图标怎么和你提供的SQL语句关联

#27楼  回复 引用 查看   

这样不得把整张表都更新一遍

这样是一件很可怕的事情啊 相当影响效率啊
2010-09-29 12:11 | zisehudie       

#28楼  回复 引用 查看   

吉日的代码就是很实际,顶一个
2010-09-29 12:18 | Peter_pan       

#29楼[楼主]  回复 引用 查看   

@zisehudie
没有把整张表都更新的,都更新单个

#30楼  回复 引用 查看   

大哥 顶一个!
2010-10-02 19:16 | 不诉离殇       

#31楼[楼主]  回复 引用 查看   

@不诉离殇
谢谢你的支持啊
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值