C#去除DataTable重復(fù)數(shù)據(jù)的三種方法
業(yè)務(wù)需求
最近做一個把源數(shù)據(jù)庫的數(shù)據(jù)批次導(dǎo)出到目標(biāo)數(shù)據(jù)庫。源數(shù)據(jù)庫是采集程序采集而來的原始數(shù)據(jù)庫,所以需要對其進行一些處理(過濾一些為空,長度太短或太長,非法字符,重復(fù)數(shù)據(jù))然后在進行入庫。
其中要避免目標(biāo)庫插入重復(fù)數(shù)據(jù)。這重復(fù)數(shù)據(jù)可能是源數(shù)據(jù)庫本身就有重復(fù)數(shù)據(jù),還有就是已經(jīng)插入避免重復(fù)插入。
過濾自身重復(fù)數(shù)據(jù)解決方案
第一種:采用DataView.ToTable()方法
- DataView.ToTable 方法
- .NET Framework 2.0
其根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個新的DataTable。
重載列表
名稱 | 說明 |
---|---|
DataView.ToTable () | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。
由 .NET Compact Framework 支持。 |
DataView.ToTable (String) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。
由 .NET Compact Framework 支持。 |
DataView.ToTable (Boolean, String[]) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。
由 .NET Compact Framework 支持。 |
DataView.ToTable (String, Boolean, String[]) | 根據(jù)現(xiàn)有 DataView 中的行,創(chuàng)建并返回一個新的 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; }
第二種方法:循環(huán)遍歷+DataTable.Select()
利用for循環(huán)遍歷DataTable的數(shù)據(jù)行,利用DataTable.Select 方法判斷是否重復(fù),如果重復(fù),則利用DataTable.Rows.RemoveAt(Index)刪除重復(fù)的那一行。
具體看代碼。
代碼示例
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; }
第三種方法
利用雙循環(huán)遍歷(不推薦)
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; }
到此這篇關(guān)于C#去除DataTable重復(fù)數(shù)據(jù)的三種方法的文章就介紹到這了,更多相關(guān)C#去除DataTable重復(fù)數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
C#數(shù)據(jù)類型實現(xiàn)背包、隊列和棧
本文詳細(xì)講解了C#數(shù)據(jù)結(jié)構(gòu)類型,并實現(xiàn)背包、隊列和棧的方法,文中通過示例代碼介紹的非常詳細(xì)。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-04-04C#實現(xiàn)圖表中鼠標(biāo)移動并顯示數(shù)據(jù)
這篇文章主要為大家詳細(xì)介紹了C#實現(xiàn)圖表中鼠標(biāo)移動并顯示數(shù)據(jù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-02-02關(guān)于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.
本篇文章,小編為大家介紹關(guān)于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.NET4中的使用介紹方法,有需要的朋友可以參考一下2013-04-04C#實現(xiàn)實體類與字符串互相轉(zhuǎn)換的方法
這篇文章主要介紹了C#實現(xiàn)實體類與字符串互相轉(zhuǎn)換的方法,涉及C#字符串及對象的相互轉(zhuǎn)換技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-08-08解決unity rotate旋轉(zhuǎn)物體 限制物體旋轉(zhuǎn)角度的大坑
這篇文章主要介紹了解決unity rotate旋轉(zhuǎn)物體 限制物體旋轉(zhuǎn)角度的大坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2021-04-04