主页 > 知识库 > 删除DataTable重复列,只删除其中的一列重复行的解决方法

删除DataTable重复列,只删除其中的一列重复行的解决方法

热门标签:电子围栏 Mysql连接数设置 Linux服务器 银行业务 阿里云 科大讯飞语音识别系统 服务器配置 团购网站

vs2005针对datatable已经有封装好的去重复方法:

复制代码 代码如下:

//去掉重复行
 DataView dv = table.DefaultView;
 table = dv.ToTable(true, new string[] { "name", "code" });

 此时table 就只有name、code无重复的两行了,如果还需要id值则

 table = dv.ToTable(true, new string[] { "id","name", "code" });//第一个参数true 启用去重复,类似distinct

如果有一组数据(id不是唯一字段)

复制代码 代码如下:

id   name   code
    张三    123
    李四    456
    张三    456
   张三     123

通过上面的方法得到

复制代码 代码如下:

id   name   code
    张三    123
    李四    456
    张三    456

去重复去掉的仅仅是 id name code完全重复的行,如果想要筛选的数据仅仅是name不允许重复呢?

复制代码 代码如下:

table = dv.ToTable(true, new string[] { "name"});

得到:

复制代码 代码如下:

name

张三 

李四 

但是我想要的结果是只针对其中的一列name列 去重复,还要显示其他的列

需要的结果是:

复制代码 代码如下:

 id   name   code


1    张三    123

2    李四    456


这个该怎么实现?下面的方法就可以,也许有更好的方法,希望大家多多指教

复制代码 代码如下:

#region 删除DataTable重复列,类似distinct
         /// summary>  
         /// 删除DataTable重复列,类似distinct  
         /// /summary>  
         /// param name="dt">DataTable/param>  
         /// param name="Field">字段名/param>  
         /// returns>/returns>  
         public static DataTable DeleteSameRow(DataTable dt, string Field)
         {
             ArrayList indexList = new ArrayList();
             // 找出待删除的行索引  
             for (int i = 0; i dt.Rows.Count - 1; i++)
             {
                 if (!IsContain(indexList, i))
                 {
                     for (int j = i + 1; j dt.Rows.Count; j++)
                     {
                         if (dt.Rows[i][Field].ToString() == dt.Rows[j][Field].ToString())
                         {
                             indexList.Add(j);
                         }
                     }
                 }
             }
             // 根据待删除索引列表删除行  
             for (int i = indexList.Count - 1; i >= 0; i--)
             {
                 int index = Convert.ToInt32(indexList[i]);
                 dt.Rows.RemoveAt(index);
             }
             return dt;
         }

         /// summary>  
         /// 判断数组中是否存在  
         /// /summary>  
         /// param name="indexList">数组/param>  
         /// param name="index">索引/param>  
         /// returns>/returns>  
         public static bool IsContain(ArrayList indexList, int index)
         {
             for (int i = 0; i indexList.Count; i++)
             {
                 int tempIndex = Convert.ToInt32(indexList[i]);
                 if (tempIndex == index)
                 {
                     return true;
                 }
             }
             return false;
         }
         #endregion

您可能感兴趣的文章:
  • 分享SQL Server删除重复行的6个方法
  • sqlserver利用存储过程去除重复行的sql语句
  • 删除Table表中的重复行的方法
  • SQLServe 重复行删除方法
  • 批处理 删除重复行的代码
  • 用vbscript实现从文本文件中删除所有重复行的代码
  • sql里将重复行数据合并为一行数据使用逗号进行分隔

标签:大理 衡水 萍乡 衢州 蚌埠 枣庄 广元 江苏

巨人网络通讯声明:本文标题《删除DataTable重复列,只删除其中的一列重复行的解决方法》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266