最近项目里遇到这样的一个小技术问题,新闻可以任意按客户的需要进行排序,需要实现的效果图如下:
由于各种类别输入了蛮多测试信息,有几百条数据,一个个把排序码都生成也很麻烦,看能否没有什么好办法能生成不重复的,唯一排序码?达到如下效果?
总不可能人工的一个个输入吧? 也没那个耐心的,还是想想有什么好办法吧?
其实很快就想到了 ROW_NUMBER() 功能,用这个,应该是可行的,折腾了一小会儿,这个SQL语句就写好了,给大家分享一下,有需要的朋友们可以直接拿过来就可以用了,虽然也没什么难的,但是自己写总会折腾一会儿,直接复制过去修改一下,省心省事一些。
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一下就可以用了.
若有谁可以写得更好,也可以贴出来分享一下。
四个按钮中的代码实现可以参考一下

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) 编辑 收藏
评论
1932808#2楼[楼主] 回复 引用 查看
@cnwei热烈欢迎,很简单的一个东东。
#3楼 回复 引用 查看
思想很好,学习了,thanks#4楼 回复 引用 查看
好#5楼 回复 引用 查看
i have ever meet the problem before#6楼 回复 引用 查看
为什么不用 Sequence ?用 Sequence 不是更好#7楼 回复 引用 查看
支持#8楼[楼主] 回复 引用 查看
@Jeffery Yousqlserver 有这个东西吗?
#9楼 回复 引用 查看
改一条新闻的次序,还得把整个表的序列重新更新一次?#10楼 回复 引用 查看
呵呵,我还以为是 Oracle!不好意思。不过,你也没说这是 SQL Server 啊,从文章中我也没看出来,而且 ROW_NUMBER 第一反应就是 Oracle,SQL Server 是后来才有的。
#11楼[楼主] 回复 引用 查看
@taia主要是有一大堆人工输入的测试数据在的
#12楼 回复 引用
太基础了!#13楼[楼主] 回复 引用 查看
若是不太基础了,你也看不出是太基础了,呵呵。#14楼 回复 引用 查看
以前排序都是直接使用datetime,目前好像没有这种需求了。#15楼 回复 引用 查看
UPDATE BASE_NEWSSET 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子句出来,这种写法还是第一次看到。
#16楼[楼主] 回复 引用 查看
@Jeffrey.Liang你说到点子上了,技术就体现在 FROM 而且是虚拟的表上。
小子洞察力很强的嘛
#17楼 回复 引用 查看
用(当前ID-最小id)+100000#18楼 回复 引用 查看
吉日兄,顶一个,基础但实用#19楼 回复 引用 查看
我操,我想死。#20楼 回复 引用 查看
SQL 语句我能理解,可是这个SQL语句怎么解决客户自定义排序我没怎么看明白, 我看顺序是上移一个,下移一个或是到顶或是到尾是吧?#21楼[楼主] 回复 引用 查看
@随处走走置顶、上移、下移、置底
#22楼 回复 引用 查看
有没有比较好的方法对换两条记录的排序号#23楼 回复 引用 查看
我用一个时间字段来排序的#24楼 回复 引用 查看
哎哟,不错哦!!!#25楼 回复 引用 查看
@吉日嘎拉 不仅权限管理。。。我能看懂那四个图标, 我是没看懂这四个图标怎么和你提供的SQL语句关联
#26楼[楼主] 回复 引用 查看
那4个图标对应的代码,就是C#写的了,不是sql语句了,我把代码也贴上,给大家一个参考好了。#27楼 回复 引用 查看
这样不得把整张表都更新一遍这样是一件很可怕的事情啊 相当影响效率啊
#28楼 回复 引用 查看
吉日的代码就是很实际,顶一个#29楼[楼主] 回复 引用 查看
@zisehudie没有把整张表都更新的,都更新单个
#30楼 回复 引用 查看
大哥 顶一个!#31楼[楼主] 回复 引用 查看
@不诉离殇谢谢你的支持啊