帝国CMS模板大全
www.admin99.cn
www.92cms.cn 帝国CMS模板下载站!,情怀,养站,二次开发!源码需求比较大的一站式会员下载,价更省!!!

C#去除DataTable重复数据的三种方法

业务需求

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

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

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

第一种:采用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重复数据内容请搜索www.admin99.cn以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.admin99.cn!

赞(0)
版权声明:本文采用知识共享 署名4.0国际许可协议 [BY-NC-SA] 进行授权
文章名称:《C#去除DataTable重复数据的三种方法》
文章链接:https://www.admin99.cn/7462
本站资源仅供个人学习交流,请于下载后24小时内删除,不允许用于商业用途,否则法律问题自行承担。
QQ站长交流群:953950264

登录

找回密码

注册