温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-05-09 13:11:51 来源:网络 阅读:526 作者:jirigala_bao 栏目:web开发

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

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

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

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

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

 

其实很快就想到了 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一下就可以用了. 

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

 

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

 

巧用 ROW_NUMBER() 生成不重复的唯一排序码,按客户的需要任意排序数据巧用 ROW_NUMBER() 生成不重复的唯一排序码,按客户的需要任意排序数据代码
 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

 

 

 

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

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

Add your comment

32 条回复

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

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

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

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

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

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

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI