亚洲乱色熟女一区二区三区丝袜,天堂√中文最新版在线,亚洲精品乱码久久久久久蜜桃图片,香蕉久久久久久av成人,欧美丰满熟妇bbb久久久

LOGO OA教程 ERP教程 模切知識(shí)交流 PMS教程 CRM教程 開(kāi)發(fā)文檔 其他文檔  
 
網(wǎng)站管理員

C#中去重的高級(jí)方法,你了解幾個(gè)?

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

今天我們一起來(lái)討論一下關(guān)于C#數(shù)據(jù)去重的常見(jiàn)的幾種方式,每種方法都有其特點(diǎn)和適用場(chǎng)景,我們根據(jù)具體需求選擇最合適的方式。當(dāng)然歡迎你在評(píng)論區(qū)留下你覺(jué)得更好的數(shù)據(jù)去重的方式。以下是一些常見(jiàn)的方法:

1、使用DISTINCT關(guān)鍵字:

在SQL查詢中,可以使用DISTINCT關(guān)鍵字來(lái)刪除重復(fù)的行。在C#中,可以使用LINQ和SqlCommand對(duì)象來(lái)執(zhí)行類似的查詢。例如:

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())

            {

                // 處理結(jié)果

            }

        }

    }

}

2、使用HashSet:

HashSet是一個(gè)不包含重復(fù)元素的集合。可以使用它來(lái)快速查找和刪除重復(fù)項(xiàng)。例如:

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);

在這個(gè)例子中,result列表只包含不重復(fù)的數(shù)字。

3、使用LINQ:

LINQ是C#中強(qiáng)大的查詢語(yǔ)法,可以用于過(guò)濾、排序和組合數(shù)據(jù)集。使用LINQ,可以非常容易地刪除重復(fù)項(xiàng)。例如:

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

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

這個(gè)例子使用LINQ的Distinct方法來(lái)刪除重復(fù)的數(shù)字。

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

GroupBy()方法將原始集合中的元素進(jìn)行分組,根據(jù)指定的鍵或條件進(jìn)行分組。每個(gè)分組都會(huì)有一個(gè)唯一的鍵,通過(guò)將原始集合分組并選擇每個(gè)分組中的第一個(gè)元素,實(shí)現(xiàn)了去重的效果。

/// <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()方法將原始集合中的元素進(jìn)行分組,根據(jù)指定的鍵或條件進(jìn)行分組。每個(gè)分組都會(huì)有一個(gè)唯一的鍵,通過(guò)將原始集合分組并選擇每個(gè)分組中的第一個(gè)元素,實(shí)現(xiàn)了去重的效果。

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

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

}

5、使用自定義的比較器和循環(huán)遍歷

    public class ArrayDeduplication

    {

        /// <summary>

        /// 使用自定義的比較器和循環(huán)遍歷

        /// </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、直接循環(huán)遍歷去重

/// <summary>

/// 直接循環(huán)遍歷去重

/// </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 編輯過(guò)
關(guān)鍵字查詢
相關(guān)文章
正在查詢...
點(diǎn)晴ERP是一款針對(duì)中小制造業(yè)的專業(yè)生產(chǎn)管理軟件系統(tǒng),系統(tǒng)成熟度和易用性得到了國(guó)內(nèi)大量中小企業(yè)的青睞。
點(diǎn)晴PMS碼頭管理系統(tǒng)主要針對(duì)港口碼頭集裝箱與散貨日常運(yùn)作、調(diào)度、堆場(chǎng)、車隊(duì)、財(cái)務(wù)費(fèi)用、相關(guān)報(bào)表等業(yè)務(wù)管理,結(jié)合碼頭的業(yè)務(wù)特點(diǎn),圍繞調(diào)度、堆場(chǎng)作業(yè)而開(kāi)發(fā)的。集技術(shù)的先進(jìn)性、管理的有效性于一體,是物流碼頭及其他港口類企業(yè)的高效ERP管理信息系統(tǒng)。
點(diǎn)晴WMS倉(cāng)儲(chǔ)管理系統(tǒng)提供了貨物產(chǎn)品管理,銷售管理,采購(gòu)管理,倉(cāng)儲(chǔ)管理,倉(cāng)庫(kù)管理,保質(zhì)期管理,貨位管理,庫(kù)位管理,生產(chǎn)管理,WMS管理系統(tǒng),標(biāo)簽打印,條形碼,二維碼管理,批號(hào)管理軟件。
點(diǎn)晴免費(fèi)OA是一款軟件和通用服務(wù)都免費(fèi),不限功能、不限時(shí)間、不限用戶的免費(fèi)OA協(xié)同辦公管理系統(tǒng)。
Copyright 2010-2025 ClickSun All Rights Reserved