博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
去除DataTable重复数据的三种方法(转)
阅读量:5104 次
发布时间:2019-06-13

本文共 1993 字,大约阅读时间需要 6 分钟。

转自:https://www.cnblogs.com/sunxi/p/4767577.html

业务需求

最近做一个把源数据库的数据批次导出到目标数据库。源数据库是采集程序采集而来的原始数据库,所以需要对其进行一些处理(过滤一些为空,长度太短或太长,非法字符,重复数据)然后在进行入库。

其中要避免目标库插入重复数据。这重复数据可能是源数据库本身就有重复数据,还有就是已经插入避免重复插入。

过滤自身重复数据解决方案

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

DataView.ToTable 方法

.NET Framework 2.0
 
其根据现有   中的行,创建并返回一个新的  。
如果指定了自定义列,会根据自定义列后的数据进行去重。

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

由 .NET Compact Framework 支持。

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

由 .NET Compact Framework 支持。

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

由 .NET Compact Framework 支持。

根据现有 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;          }

转载于:https://www.cnblogs.com/alsf/p/8709958.html

你可能感兴趣的文章
Android定制组件之Widget之昨天今天明天
查看>>
JSON
查看>>
JavaScript中的匿名函数及函数的闭包
查看>>
【JMeter】选项-函数助手对话框应用举例
查看>>
2012年实习总结
查看>>
安装Cocoapods(MAC 10.11.1 安装不成功修正完毕)
查看>>
Git初始化的相关问题
查看>>
2015-7-1 记而随,随而记
查看>>
生产者消费者问题
查看>>
如何在Access2007中使用日期类型查询数据
查看>>
Jzoj4757 树上摩托
查看>>
CF992E Nastya and King-Shamans(线段树二分+思维)
查看>>
基于docker的spark-hadoop分布式集群之一: 环境搭建
查看>>
oracle 几个时间函数探究
查看>>
第一个Java Web程序
查看>>
Atomic
查看>>
div 显示滚动条与div显示隐藏的CSS代码
查看>>
Redis-1-安装
查看>>
Access denied for user ''@'localhost' to database 'mysql'
查看>>
微信公众号里面使用地图导航
查看>>