巧用 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一下就可以用了.

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

 

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

 

代码   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

 

---------------------------

DataList和GridView的取值经验

 

 

在GridView或DataList中进行数据的修改或者删除操作时,总是要先获取记录的主键,我以前就是在数据绑定时,给操作按钮的CommandArgument赋主键值.现在,I prefer to some new methods.首先,介绍GridView的相关操作.

首先绑定DataKeyNames,

GridView.DataKeyNames = new string[] { "字段名称" };

string value= GridView.DataKeys[e.Row.RowIndex].Value.ToString();

DataKeyNames="ID" 绑定一个值
GridView1.DataKeys[e.Row.RowIndex].Value.ToString();

DataKeyNames="ID,Name" 绑定两个值
GridView1.DataKeys[e.Row.RowIndex].Values[0].ToString();
GridView1.DataKeys[e.Row.RowIndex].Values[1].ToString();

如果不设,就获取绑定信息的主键.

据我所知,只有在gridview的RowDataBound事件中e.Row.RowIndex才有用,e.Row.RowIndex是当前行,而整个GridView1.DataKeys[e.Row.RowIndex].Value.ToString()获取的是当前行的主键.还有诸如 e.Row.Cells[0].Text的方法,获取主键.

DataList的操作

在ItemCommand事件中,DataList.DataKeys[e.Item.ItemIndex]获取主键.

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值