时间:2021-05-20
最近做一个把源数据库的数据批次导出到目标数据库。源数据库是采集程序采集而来的原始数据库,所以需要对其进行一些处理(过滤一些为空,长度太短或太长,非法字符,重复数据)然后在进行入库。
其中要避免目标库插入重复数据。这重复数据可能是源数据库本身就有重复数据,还有就是已经插入避免重复插入。
过滤自身重复数据解决方案
其根据现有 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; }利用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重复数据内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
C#过滤DataTable中的空数据和重复数据stringsql="selectname,agefromuser";DataTabledata=DB.Execu
本文实例讲述了C#中datatable去重的方法,分享给大家供大家参考。具体方法如下:这里主要介绍两种方法:1数据库直接去除重复复制代码代码如下:selectd
C#中保存Session的三种方法及Web.Config设置保存session到sqlserver;,需要指定SqlServer;服务器,这种方法因为要读写数据
混乱的URI编码 JavaScript中编码有三种方法:escape、encodeURI、encodeURIComponent C#中编码主要方法:Http
总的思路就是先找出表中重复数据中的一条数据,插入临时表中,删除所有的重复数据,然后再将临时表中的数据插入表中。所以重点是如何找出重复数据中的一条数据,有三种