[C#] LINQ之Join與GroupJoin

来源:https://www.cnblogs.com/cncc/archive/2018/10/29/9873144.html
-Advertisement-
Play Games

聲明:本文為www.cnc6.cn原創,轉載時請註明出處,謝謝! 一、編寫Person與City類,如下: 二、為以上兩個類建立一些數據,存儲於persons與cities中,如下: 三、Join第一種用法: 官方釋義:基於匹配鍵對兩個序列的元素進行關聯。使用預設的相等比較器對鍵進行比較。 這個與數 ...


聲明:本文為www.cnc6.cn原創,轉載時請註明出處,謝謝!

一、編寫Person與City類,如下:

 1     class Person
 2     {
 3         public int CityID { set; get; }
 4         public string Name { set; get; }
 5     }
 6     class City
 7     {
 8         public int ID { set; get; }
 9         public string Name { set; get; }
10     }

二、為以上兩個類建立一些數據,存儲於persons與cities中,如下:

 1     Person[] persons = new Person[]
 2     {
 3         new Person{ CityID = 1, Name = "ABC" },
 4         new Person{ CityID = 1, Name = "EFG" },
 5         new Person{ CityID = 2, Name = "HIJ" },
 6         new Person{ CityID = 3, Name = "KLM" },
 7         new Person{ CityID = 3, Name = "NOP" },
 8         new Person{ CityID = 4, Name = "QRS" },
 9         new Person{ CityID = 5, Name = "TUV" }
10     };
11     City[] cities = new City[]
12     {
13         new City{ ID = 1,Name = "Guangzhou" },
14         new City{ ID = 2,Name = "Shenzhen" },
15         new City{ ID = 3,Name = "Beijing" },
16         new City{ ID = 4,Name = "Shanghai" }
17     };

三、Join第一種用法:

public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>(this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, TInner, TResult> resultSelector);

官方釋義:基於匹配鍵對兩個序列的元素進行關聯。使用預設的相等比較器對鍵進行比較。

這個與資料庫中的INNER JOIN很類似,就是使用一個鍵(TKey)將兩個集合關聯起來,並對這兩個集合的元素進行選擇,作為結果輸出。

1、數據源本身為outer,需要作Join連接的集合為inner;

2、選擇一個outer內的一個元素,作為輸入參數,並輸出一個基於outer的鍵值;

3、選擇一個inner內的一個元素,作為輸入參數,並輸出一個基於inner的鍵值;

4、將基於outer的鍵值與inner的鍵值作為輸入參數,並輸出一個自己定義類型的結果選擇器;

5、返回的結果就是自己定義類型的集合。

編寫客戶端試驗代碼:

1     var result =  persons.Join(cities, p => p.CityID, c => c.ID, (p, c) => new { PersonName = p.Name, CityName = c.Name});
2     foreach(var item in result)
3     {
4         Console.WriteLine($"{item.PersonName},{item.CityName}");
5     }

從以上可以看出,persons為outer集合,cities為inner集合,p.CityID為outer的鍵值,c.ID為inner的鍵值,Join就是將persons內CityID與cities內ID相等性連接起來,並將persons內的每個元素及cities內的每個元素作為輸入參數,從從選擇自己想要的數據,如自己定義的匿名類型。

因為persons內CityID為5的城市編號不存在與cIties內,因此輸出結果不會含Name為“TUV”的信息。

輸出結果如下:

其等價的LINQ語句為:

1     var result = from p in persons
2                  join c in cities on p.CityID equals c.ID
3                  select new { PersonName = p.Name, CityName = c.Name };

四、Join第二種用法:

public static IEnumerable<TResult> Join<TOuter, TInner, TKey, TResult>(this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, TInner, TResult> resultSelector, IEqualityComparer<TKey> comparer);

官方釋義:基於匹配鍵對兩個序列的元素進行關聯。使用指定的IEqualityComparer<TKey> 對鍵進行比較。

以上與Join第一種方法無非就是多一個IEqualityComparer<TKey>,如果使用一個繼承於IEqualityComparer<TKey>的類初始化comparer,它就會使用該類對對TOuter.TKey及TInner.TKey進行相等性比較,判斷是否進行連接,並輸出自己定義的類型集合。

五、GroupJoin第一種方法:

public static IEnumerable<TResult> GroupJoin<TOuter, TInner, TKey, TResult>(this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, IEnumerable<TInner>, TResult> resultSelector);

官方釋義: 基於鍵相等對兩個序列的元素進行關聯並對結果進行分組。使用預設的相等比較器對鍵進行比較。

這個與資料庫的LEFT OUTER JOIN很類似。與Join的區別就是:GroupJoin內resultSelector的輸入參數從TInner單個元素編程IEnumerable<TInner>元素集合,其他保持不變。用法與Join差不多,它也是基於TOuter.TKey及TInner.TKey的連接。

編寫客戶端試驗代碼:

 1     var result = persons.GroupJoin(cities, p => p.CityID, c => c.ID, (p, cs) => new { PersonName = p.Name, Citys = cs });
 2     foreach (var item in result)
 3     {
 4         Console.Write($"{item.PersonName}\t");
 5         foreach (var city in item.Citys)
 6         {
 7             Console.Write($"{city.Name}");
 8         }
 9         Console.WriteLine();
10     }

這個輸出會將Name為“TUV”的名字輸出,但其城市卻是空的,原因就是在cities找不到編號為5的City信息。

輸出結果如下:

其等價的LINQ語句為:

1     var result = from p in persons
2                  join c in cities on p.CityID equals c.ID into cs
3                  select new { PersonName = p.Name, Citys = cs };

六、GroupJoin第二種方法:

public static IEnumerable<TResult> GroupJoin<TOuter, TInner, TKey, TResult>(this IEnumerable<TOuter> outer, IEnumerable<TInner> inner, Func<TOuter, TKey> outerKeySelector, Func<TInner, TKey> innerKeySelector, Func<TOuter, IEnumerable<TInner>, TResult> resultSelector, IEqualityComparer<TKey> comparer);

官方釋義:基於鍵相等對兩個序列的元素進行關聯並對結果進行分組。使用指定的IEqualityComparer<TKey>對鍵進行比較。

這個與Join第二種方法類似,這裡不再進行講述。


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Python爬蟲目前是基於requests包,下麵是該包的文檔,查一些資料還是比較方便。 http://docs.python-requests.org/en/master/ 爬取某旅游網站的產品評論,通過分析,獲取json文件需要POST指令。簡單來說: GET是將需要發送的信息直接添加在網址後面 ...
  • 1、基礎介紹 常用功能 1、HTTP服務 動靜分離、WEB緩存、虛擬主機設置、URL Rewrite 2、負載均衡 3、反向代理 4、正向代理 5、郵件伺服器 優點 高擴展、高可用、支持高併發、低資源消耗、可平滑升級重啟(熱部署) 2、安裝部署 1、下載 nginx-1.15.3.tar.gz 2、 ...
  • 繼續上次的進度:https://www.cnblogs.com/flashBoxer/p/9847521.html 正文: 裝飾類 在類中有兩種不通的方式使用裝飾器,第一個和我們之前做過的函數非常相似:在類的方法上應用。這也是當時引入裝飾器的原因之一一些常用的裝飾器已經內置到python中,像@cl ...
  • 一、環境 tomcat7.0、notepad++(這個是一個文本編輯器,用記事本也可以)二、修改方法 例如:現在把預設的8080埠改成8082埠 第一步:找到tomcat7的conf目錄下的 server.xml這個文件,並用notepad++打開。 第二步:將 改成 (可以利用ctrl+f 快... ...
  • 開發語言 高級語言:基於C/彙編等封裝的語言,如Python、Java、C#、PHP、Go、ruby、C++……生成位元組碼讓C/彙編去識別 低級語言:直接讓電腦底層能識別成機器碼的語言(電腦再將機器碼識別為0101010……),如C、彙編等 Python特點:開發效率高,執行效率低,但 摩爾定律 ...
  • maven pom屬性 內置屬性(預定義,可直接使用) ${basedir} 表示項目根目錄,即包含pom.xml文件的目錄; ${version} 表示項目版本; ${project.basedir}同${basedir}; ${maven.build.timestamp} 表示項目構件開始時間; ...
  • 本博客主要介紹通過 Javassist、ASM 操作 Java 位元組碼。 Class 文件是什麼 通常對於用 idea 的同學來說,class 文件是直接可以查看的,可以看到像 java 那樣的代碼。其實 class 文件是一種位元組碼文件,我們平時在 idea 所看到的,是 idea 自動反編譯後的 ...
  • 引用鏈接:https://www.cnblogs.com/duwenxing/p/7421100.html 目的 用途 1.在引用的使用中,單純給某個變數去別名是毫無意義的,引用的目的主要用於在函數參數的傳遞中,解決大塊數據或對象的傳遞效率和空間不如意的問題 2.用引用傳遞函數的參數,能保證參數在傳 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...