怎么在C#中去除DataTable中的重复数据-创新互联

本篇文章为大家展示了怎么在C#中去除DataTable中的重复数据,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

创新互联-专业网站定制、快速模板网站建设、高性价比雁峰网站开发、企业建站全套包干低至880元,成熟完善的模板库,直接使用。一站式雁峰网站制作公司更省心,省钱,快速模板网站建设找我们,业务覆盖雁峰地区。费用合理售后完善,10年实体公司更值得信赖。

第一种:采用DataView.ToTable()方法

  • DataView.ToTable 方法

  • .NET Framework 2.0


其根据现有 DataView 中的行,创建并返回一个新的DataTable。


重载列表

名称说明
DataView.ToTable ()根据现有 DataView 中的行,创建并返回一个新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (String)根据现有 DataView 中的行,创建并返回一个新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (Boolean, String[])根据现有 DataView 中的行,创建并返回一个新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (String, Boolean, String[])根据现有 DataView 中的行,创建并返回一个新的 DataTable。

由 .NET Compact Framework 支持。

实例代码

 public static DataTable Distinct(DataTable dt, string[] filedNames)
  {
   DataView dv = dt.DefaultView;
   DataTable DistTable = dv.ToTable("Dist", true, filedNames);
   return DistTable;
  }

第二种方法:循环遍历+DataTable.Select()

利用for循环遍历DataTable的数据行,利用DataTable.Select 方法判断是否重复,如果重复,则利用DataTable.Rows.RemoveAt(Index)删除重复的那一行。

具体看代码。

代码示例

 public DataTable GetDistinctSelf(DataTable SourceDt, string filedName)
  {
 for (int i = SourceDt.Rows.Count - 2; i > 0; i--)
   {
    DataRow[] rows = SourceDt.Select(string.Format("{0}='{1}'", filedName, SourceDt.Rows[i][filedName]));
    if (rows.Length > 1)
    {
     SourceDt.Rows.RemoveAt(i);
    }
   }
   return SourceDt;  
  }

第三种方法

利用双循环遍历(不推荐)

 public DataTable GetDistinctSelf(DataTable SourceDt, string filedName)
  {
   for (int i = SourceDt.Rows.Count - 2; i > 0; i--)
   {
    string title = SourceDt.Rows[0][filedName].ToString();
    for (int j = i + 1; j > 0; i--)
    {
     if (SourceDt.Rows[j][filedName].ToString() == title)
     {
      SourceDt.Rows.RemoveAt(i);

     }
    }

   }
   return SourceDt;
   }

上述内容就是怎么在C#中去除DataTable中的重复数据,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注创新互联行业资讯频道。


文章题目:怎么在C#中去除DataTable中的重复数据-创新互联
浏览地址:http://scyanting.com/article/psshd.html