欧美成人精品手机在线观看_69视频国产_动漫精品第一页_日韩中文字幕网 - 日本欧美一区二区

LOGO OA教程 ERP教程 模切知識交流 PMS教程 CRM教程 開發文檔 其他文檔  
 
網站管理員

C#中去重的高級方法,你了解幾個?

admin
2023年10月10日 10:30 本文熱度 653

今天我們一起來討論一下關于C#數據去重的常見的幾種方式,每種方法都有其特點和適用場景,我們根據具體需求選擇最合適的方式。當然歡迎你在評論區留下你覺得更好的數據去重的方式。以下是一些常見的方法:

1、使用DISTINCT關鍵字:

在SQL查詢中,可以使用DISTINCT關鍵字來刪除重復的行。在C#中,可以使用LINQ和SqlCommand對象來執行類似的查詢。例如:

string connString = "Your Connection String";

using (SqlConnection conn = new SqlConnection(connString)){

    conn.Open();

    string sql = "select DISTINCT column1, column2 from your_table";

    using (SqlCommand cmd = new SqlCommand(sql, conn))

    {

        using (SqlDataReader reader = cmd.executeReader())

        {

            while (reader.Read())

            {

                // 處理結果

            }

        }

    }

}

2、使用HashSet:

HashSet是一個不包含重復元素的集合。可以使用它來快速查找和刪除重復項。例如:

List<int> numbers = new List<int> { 1, 2, 3, 4, 4, 5, 5, 6 };

HashSet<int> uniqueNumbers = new HashSet<int>(numbers);

List<int> result = new List<int>(uniqueNumbers);

在這個例子中,result列表只包含不重復的數字。

3、使用LINQ:

LINQ是C#中強大的查詢語法,可以用于過濾、排序和組合數據集。使用LINQ,可以非常容易地刪除重復項。例如:

List<int> numbers = new List<int> { 1, 2, 3, 4, 4, 5, 5, 6 };

var uniqueNumbers = numbers.Distinct().ToList();

這個例子使用LINQ的Distinct方法來刪除重復的數字。

4、使用Linq的GroupBy()方法去重

GroupBy()方法將原始集合中的元素進行分組,根據指定的鍵或條件進行分組。每個分組都會有一個唯一的鍵,通過將原始集合分組并選擇每個分組中的第一個元素,實現了去重的效果。

/// <summary>

/// 使用LinqGroupBy()方法去重

/// </summary>

public static void GroupByDuplicate()

{

    var dataSource = new List<int>() { 1, 2, 3, 2, 5, 88, 99, 99, 100, 88, 30, 50, 15, 100, 99, 99, 2, 3 };

     //GroupBy()方法將原始集合中的元素進行分組,根據指定的鍵或條件進行分組。每個分組都會有一個唯一的鍵,通過將原始集合分組并選擇每個分組中的第一個元素,實現了去重的效果。

    var uniqueData = dataSource.GroupBy(item => item).select(group => group.First()).ToList();

     Console.WriteLine(string.Join(", ", uniqueData));

}

5、使用自定義的比較器和循環遍歷

    public class ArrayDeduplication

    {

        /// <summary>

        /// 使用自定義的比較器和循環遍歷

        /// </summary>

        public static void CustomEqualityComparerDuplicate(){

            var dataSource = new List<int>() { 1232588999910088305015100999923 };

            var uniqueData = new List<int>();

            foreach (var item in dataSource)

            {

                if (!uniqueData.Contains(item, new CustomEqualityComparer()))

                {

                    uniqueData.Add(item);

                }

            }

            Console.WriteLine(string.Join(", ", uniqueData));

        }

    }

            /// <summary>

    /// 自定義的比較器

    /// </summary>

    public class CustomEqualityComparer : IEqualityComparer<int>

    {

        public bool Equals(int x, int y){

            return x == y;

        }

         public int GetHashCode(int obj){

            return obj.GetHashCode();

        }

    }


6、直接循環遍歷去重

/// <summary>

/// 直接循環遍歷去重

/// </summary>

public static void LoopTraversalDuplicate()

{

    var dataSource = new List<int>() { 1, 2, 3, 2, 5, 88, 99, 99, 100, 88, 30, 50, 15, 100, 99, 99, 2, 3 };

    var uniqueData = new List<int>();

    foreach (var item in dataSource)

    {

        //if (!uniqueData.Any(x => x == item))

        //if (!uniqueData.Exists(x => x == item))

        if (!uniqueData.Contains(item))

        {

            uniqueData.Add(item);

        }

    }

    Console.WriteLine(string.Join(", ", uniqueData));

}


該文章在 2023/10/10 10:30:21 編輯過
關鍵字查詢
相關文章
正在查詢...
點晴ERP是一款針對中小制造業的專業生產管理軟件系統,系統成熟度和易用性得到了國內大量中小企業的青睞。
點晴PMS碼頭管理系統主要針對港口碼頭集裝箱與散貨日常運作、調度、堆場、車隊、財務費用、相關報表等業務管理,結合碼頭的業務特點,圍繞調度、堆場作業而開發的。集技術的先進性、管理的有效性于一體,是物流碼頭及其他港口類企業的高效ERP管理信息系統。
點晴WMS倉儲管理系統提供了貨物產品管理,銷售管理,采購管理,倉儲管理,倉庫管理,保質期管理,貨位管理,庫位管理,生產管理,WMS管理系統,標簽打印,條形碼,二維碼管理,批號管理軟件。
點晴免費OA是一款軟件和通用服務都免費,不限功能、不限時間、不限用戶的免費OA協同辦公管理系統。
Copyright 2010-2025 ClickSun All Rights Reserved