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

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

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

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

1UPDATEBASE_NEWS
2SETSortCode=NEWS.SortCode
3FROM(SELECTROW_NUMBER()OVER(ORDERBYCreateDateDESC)+10000000ASSortCode
4,Id
5FROMBASE_NEWS)ASNEWS
6WHERENEWS.Id=BASE_NEWS.Id复制代码

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

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

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

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

将权限管理、工作流管理做到我能力的极致,一个人只能做好那么很少的几件事情。分类: [03] 项目开发经验绿色通道:好文要顶关注我收藏该文与我联系 信息化建标准开放平台
关注 - 177
粉丝 - 1226荣誉:推荐博客+加关注306(请您对文章做出评价)« 博主前一篇:内部管理类软件基础架构思想(思路图解 + 配套免费视频)
» 博主后一篇:[走火入魔失眠夜]浅谈管理软件信息安全,用户名、密码的加密解密【附C#配套加密解密源码】

Categories: [03] 项目开发经验

Add your comment

32 条回复1996343 #1楼 cnwei2010-09-28 14:44 先顶再看o(∩_∩)o...  回复 引用 查看  #2楼[楼主] 吉日嘎拉 不仅权限管理2010-09-28 14:45 @cnwei
热烈欢迎,很简单的一个东东。
 回复 引用 查看  #3楼 寻自己2010-09-28 14:58 思想很好,学习了,thanks  回复 引用 查看  #4楼 小情2010-09-28 15:14 好  回复 引用 查看  #5楼 满晨晨2010-09-28 15:45 i have ever meet the problem before  回复 引用 查看  #6楼 Jeffery You2010-09-28 16:00 为什么不用 Sequence ?用 Sequence 不是更好  回复 引用 查看  #7楼 异乡风铃2010-09-28 16:08 支持  回复 引用 查看  #8楼[楼主] 吉日嘎拉 不仅权限管理2010-09-28 16:11 @Jeffery You
sqlserver 有这个东西吗?  回复 引用 查看  #9楼 taia2010-09-28 16:54 改一条新闻的次序,还得把整个表的序列重新更新一次?  回复 引用 查看  #10楼 Jeffery You2010-09-28 16:56 呵呵,我还以为是 Oracle!不好意思。
不过,你也没说这是 SQL Server 啊,从文章中我也没看出来,而且 ROW_NUMBER 第一反应就是 Oracle,SQL Server 是后来才有的。  回复 引用 查看  #11楼[楼主] 吉日嘎拉 不仅权限管理2010-09-28 17:36 @taia

主要是有一大堆人工输入的测试数据在的  回复 引用 查看  #12楼 Fine1[未注册用户]2010-09-28 18:00 太基础了!  回复 引用  #13楼[楼主] 吉日嘎拉 不仅权限管理2010-09-28 19:33 若是不太基础了,你也看不出是太基础了,呵呵。
引用Fine1:太基础了!

 回复 引用 查看  #14楼 lcs-帅2010-09-28 20:33 以前排序都是直接使用datetime,目前好像没有这种需求了。  回复 引用 查看  #15楼 Jeffrey.Liang2010-09-28 22:29 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子句出来,这种写法还是第一次看到。  回复 引用 查看  #16楼[楼主] 吉日嘎拉 不仅权限管理2010-09-29 00:21 @Jeffrey.Liang
你说到点子上了,技术就体现在 FROM 而且是虚拟的表上。
小子洞察力很强的嘛  回复 引用 查看  #17楼 ugvanxk2010-09-29 08:38 用(当前ID-最小id)+100000  回复 引用 查看  #18楼 总想拥有自己的天空2010-09-29 08:54 吉日兄,顶一个,基础但实用  回复 引用 查看  #19楼 鱼蛋儿2010-09-29 08:58 我操,我想死。  回复 引用 查看  #20楼 随处走走2010-09-29 09:04 SQL 语句我能理解,可是这个SQL语句怎么解决客户自定义排序我没怎么看明白, 我看顺序是上移一个,下移一个或是到顶或是到尾是吧?  回复 引用 查看  #21楼[楼主] 吉日嘎拉 不仅权限管理2010-09-29 09:31 @随处走走
置顶、上移、下移、置底  回复 引用 查看  #22楼 超级奶崽2010-09-29 09:52 有没有比较好的方法对换两条记录的排序号  回复 引用 查看  #23楼 軒轅劍2010-09-29 10:21 我用一个时间字段来排序的  回复 引用 查看  #24楼 cherry .Net2010-09-29 10:42 哎哟,不错哦!!!  回复 引用 查看  #25楼 随处走走2010-09-29 10:59 @吉日嘎拉 不仅权限管理
。。。我能看懂那四个图标, 我是没看懂这四个图标怎么和你提供的SQL语句关联  回复 引用 查看  #26楼[楼主] 吉日嘎拉 不仅权限管理2010-09-29 11:09 那4个图标对应的代码,就是C#写的了,不是sql语句了,我把代码也贴上,给大家一个参考好了。

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

 回复 引用 查看  #27楼 zisehudie2010-09-29 12:11 这样不得把整张表都更新一遍

这样是一件很可怕的事情啊 相当影响效率啊  回复 引用 查看  #28楼 Peter_pan2010-09-29 12:18 吉日的代码就是很实际,顶一个  回复 引用 查看  #29楼[楼主] 吉日嘎拉 不仅权限管理2010-09-29 13:04 @zisehudie
没有把整张表都更新的,都更新单个  回复 引用 查看  #30楼 不诉离殇2010-10-02 19:16 大哥 顶一个!  回复 引用 查看  #31楼[楼主] 吉日嘎拉 不仅权通用权限2010-10-12 13:53 @不诉离殇
谢谢你的支持啊  回复 引用 查看  #32楼 jerryloving2010-12-24 13:30 来顶顶  回复 引用 查看  刷新评论列表刷新页面返回顶部注册用户登录后才能发表评论,请 登录 或 注册,访问网站首页。简洁阅读版式网站首页博问新闻闪存程序员招聘知识库最新IT新闻:
· Zynga被OMGPOP超越 不再是Facebook游戏王
· 当当多名用户账户被盗索赔遭拒 回应让报警处理
· 新iPad入门版拆解:元件成本316美元
· 电信iPhone 4S裸机价格出炉 购买赠1050元话费
· 雅虎诉Facebook警醒创业公司:尽早申请专利
» 更多新闻...最新知识库文章:
· 循序渐进学编程
· Web开发:我希望得到的编程学习路线图
· Google Dart精粹:应用构建,快照和隔离体
· 谷歌是如何做测试的
· URL, URI 和 URN 之间的区别
» 更多知识库文章...
China-pub 2011秋季教材巡展
China-Pub 计算机绝版图书按需印刷服务
历史上的今天:
2009-09-28 一步步教你如何用疯狂.NET架构中的通用权限系统 -- 分级授权
About

吉日嘎拉(蒙古语为吉祥如意),2000年毕业于黑龙江大学计算机系软件专业,目前定居杭州,典型的IT软件土鳖一个,外号“软件包工头”。

通用权限管理系统组件(GPM - General Permissions Manager)自2003年开始发布,目前是国内注册用户和免费盗版用户最多的权限管理系统,是各种信息管理系统开发中彻底的权限解决方案。本组件支持多种主流数据库(Oracle、sqlsever、db2、mysql),功能强大,使用方便,代码简洁,思路严谨,被广大支持者称为权限管理系统中的“走火入魔级权限管理系统”。

精心维护通用权限管理系统组件(GPM - General Permissions Manager)有8年多,3年的不断推广,20万行经典的业务逻辑积累,经过上万次的调试修正,经历了四百个付费客户,上百软件公司的实战开发。

11年以上开发经验,外企工作5年,上市公司3年,独立经营软件公司2年,主持研发部门管理工作4年以上。

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


QQ:252056973,Mail:jirigala_bao@hotmail.com