欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C#去除DataTable重復數據的三種方法

 更新時間:2021年02月26日 10:13:58   作者:無憂島主  
這篇文章主要介紹了C#去除DataTable重復數據的三種方法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

業(yè)務需求

最近做一個把源數據庫的數據批次導出到目標數據庫。源數據庫是采集程序采集而來的原始數據庫,所以需要對其進行一些處理(過濾一些為空,長度太短或太長,非法字符,重復數據)然后在進行入庫。

其中要避免目標庫插入重復數據。這重復數據可能是源數據庫本身就有重復數據,還有就是已經插入避免重復插入。

過濾自身重復數據解決方案

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

  • DataView.ToTable 方法
  • .NET Framework 2.0

其根據現有 DataView 中的行,創(chuàng)建并返回一個新的DataTable

重載列表

名稱 說明
DataView.ToTable () 根據現有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (String) 根據現有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (Boolean, String[]) 根據現有 DataView 中的行,創(chuàng)建并返回一個新的 DataTable。

由 .NET Compact Framework 支持。

DataView.ToTable (String, Boolean, String[]) 根據現有 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的數據行,利用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;  
  }

第三種方法

利用雙循環(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;
   }

到此這篇關于C#去除DataTable重復數據的三種方法的文章就介紹到這了,更多相關C#去除DataTable重復數據內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • C#/.net程序調用Python的教程分享

    C#/.net程序調用Python的教程分享

    C#的優(yōu)勢在于window下的開發(fā),不僅功能強大而且開發(fā)周期短。而python則有眾多的第三方庫,可以避免自己造輪子,利用C#來做界面,而具體實現使用python來實現可以大大提高開發(fā)效率。本文介紹如何使用pythonnet來執(zhí)行python腳本,希望對大家有所幫助
    2023-03-03
  • C#數據類型實現背包、隊列和棧

    C#數據類型實現背包、隊列和棧

    本文詳細講解了C#數據結構類型,并實現背包、隊列和棧的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-04-04
  • C#實現圖表中鼠標移動并顯示數據

    C#實現圖表中鼠標移動并顯示數據

    這篇文章主要為大家詳細介紹了C#實現圖表中鼠標移動并顯示數據,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • C#中可枚舉類型詳解

    C#中可枚舉類型詳解

    這篇文章主要介紹了C#中可枚舉類型,IEnumerable和IEnumerator接口j及其泛型實現和迭代器,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • C#中的異常處理問題try catch finally

    C#中的異常處理問題try catch finally

    這篇文章主要介紹了C#中的異常處理問題try catch finally,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-11-11
  • Socket不能選擇本地IP連接問題如何解決

    Socket不能選擇本地IP連接問題如何解決

    本文將介紹一個不要手動,要用程序自動實現 ,可以綁定本地的任何IP地址,有需求的朋友可以參考下
    2012-11-11
  • 關于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.NET4中的使用介紹方法

    關于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.

    本篇文章,小編為大家介紹關于C# 5.0 CallerMemberName CallerFilePath CallerLineNumber 在.NET4中的使用介紹方法,有需要的朋友可以參考一下
    2013-04-04
  • C#實現實體類與字符串互相轉換的方法

    C#實現實體類與字符串互相轉換的方法

    這篇文章主要介紹了C#實現實體類與字符串互相轉換的方法,涉及C#字符串及對象的相互轉換技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-08-08
  • 解決unity rotate旋轉物體 限制物體旋轉角度的大坑

    解決unity rotate旋轉物體 限制物體旋轉角度的大坑

    這篇文章主要介紹了解決unity rotate旋轉物體 限制物體旋轉角度的大坑,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • C# winForm實現的氣泡提示窗口功能示例

    C# winForm實現的氣泡提示窗口功能示例

    這篇文章主要介紹了C# winForm實現的氣泡提示窗口功能,涉及C# winForm窗口屬性與設置相關操作技巧,需要的朋友可以參考下
    2018-03-03

最新評論