C#中LINQ的使用知多少?LINQ常功能整理,實例源代碼解析

来源:https://www.cnblogs.com/hanbing81868164/archive/2023/11/25/17855161.html
-Advertisement-
Play Games

LINQ(Language-Integrated Query)是C#語言中的一個強大的查詢技術,它提供了一種統一的查詢語法,可以用於查詢和操作各種數據源,包括集合、資料庫、XML等。下麵詳細描述了LINQ的20個功能點,並提供了相應的源代碼。 查詢集合中的所有元素: int[] numbers = ...


 

LINQ(Language-Integrated Query)是C#語言中的一個強大的查詢技術,它提供了一種統一的查詢語法,可以用於查詢和操作各種數據源,包括集合、資料庫、XML等。下麵詳細描述了LINQ的20個功能點,並提供了相應的源代碼。

  1. 查詢集合中的所有元素:
int[] numbers = { 1, 2, 3, 4, 5 };

var query = from num in numbers
            select num;

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 使用條件過濾集合中的元素:
int[] numbers = { 1, 2, 3, 4, 5 };

var query = from num in numbers
            where num % 2 == 0
            select num;

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 對集合中的元素進行排序:
int[] numbers = { 5, 3, 1, 4, 2 };

var query = from num in numbers
            orderby num
            select num;

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 對集合中的元素進行分組:
string[] names = { "Alice", "Bob", "Charlie", "David", "Eve" };

var query = from name in names
            group name by name[0];

foreach (var group in query)
{
    Console.WriteLine(group.Key);
    foreach (var name in group)
    {
        Console.WriteLine(name);
    }
}
  1. 對集合中的元素進行投影:
string[] names = { "Alice", "Bob", "Charlie", "David", "Eve" };

var query = from name in names
            select name.Length;

foreach (var length in query)
{
    Console.WriteLine(length);
}
  1. 連接兩個集合的元素:
string[] names1 = { "Alice", "Bob", "Charlie" };
string[] names2 = { "David", "Eve", "Frank" };

var query = from name1 in names1
            join name2 in names2 on name1[0] equals name2[0]
            select new { Name1 = name1, Name2 = name2 };

foreach (var pair in query)
{
    Console.WriteLine($"{pair.Name1}, {pair.Name2}");
}
  1. 使用LINQ查詢資料庫:
using (var dbContext = new MyDbContext())
{
    var query = from user in dbContext.Users
                where user.Age > 18
                select user;

    foreach (var user in query)
    {
        Console.WriteLine(user.Name);
    }
}
  1. 使用LINQ查詢XML文檔:
XDocument doc = XDocument.Load("data.xml");

var query = from element in doc.Descendants("book")
            where (int)element.Element("price") > 10
            select element.Element("title").Value;

foreach (var title in query)
{
    Console.WriteLine(title);
}
  1. 使用LINQ查詢JSON數據:
string json = File.ReadAllText("data.json");
var data = JsonConvert.DeserializeObject<List<Person>>(json);

var query = from person in data
            where person.Age > 18
            select person.Name;

foreach (var name in query)
{
    Console.WriteLine(name);
}
  1. 使用LINQ查詢並轉換結果:
int[] numbers = { 1, 2, 3, 4, 5 };

var query = from num in numbers
            where num % 2 == 0
            select num * 2;

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 使用LINQ查詢返回匿名類型:
string[] names = { "Alice", "Bob", "Charlie", "David", "Eve" };

var query = from name in names
            select new { Name = name, Length = name.Length };

foreach (var item in query)
{
    Console.WriteLine($"{item.Name}, {item.Length}");
}
  1. 使用LINQ查詢返回自定義類型:
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}

List<Person> people = new List<Person>
{
    new Person { Name = "Alice", Age = 20 },
    new Person { Name = "Bob", Age = 25 },
    new Person { Name = "Charlie", Age = 30 }
};

var query = from person in people
            where person.Age > 25
            select person.Name;

foreach (var name in query)
{
    Console.WriteLine(name);
}
  1. 使用LINQ查詢返回集合:
int[] numbers = { 1, 2, 3, 4, 5 };

var query = from num in numbers
            where num % 2 == 0
            select num * 2;

List<int> result = query.ToList();

foreach (var num in result)
{
    Console.WriteLine(num);
}
  1. 使用LINQ進行分頁查詢:
int pageNumber = 2;
int pageSize = 10;

var query = from product in dbContext.Products
            orderby product.Name
            select product;

var page = query.Skip((pageNumber - 1) * pageSize).Take(pageSize);

foreach (var product in page)
{
    Console.WriteLine(product.Name);
}
  1. 使用LINQ進行聚合操作:
int[] numbers = { 1, 2, 3, 4, 5 };

int sum = numbers.Sum();
int max = numbers.Max();
int min = numbers.Min();
double average = numbers.Average();

Console.WriteLine($"Sum: {sum}");
Console.WriteLine($"Max: {max}");
Console.WriteLine($"Min: {min}");
Console.WriteLine($"Average: {average}");
  1. 使用LINQ進行集合的交集操作:
int[] numbers1 = { 1, 2, 3, 4, 5 };
int[] numbers2 = { 4, 5, 6, 7, 8 };

var query = numbers1.Intersect(numbers2);

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 使用LINQ進行集合的並集操作:
int[] numbers1 = { 1, 2, 3, 4, 5 };
int[] numbers2 = { 4, 5, 6, 7, 8 };

var query = numbers1.Union(numbers2);

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 使用LINQ進行集合的差集操作:
int[] numbers1 = { 1, 2, 3, 4, 5 };
int[] numbers2 = { 4, 5, 6, 7, 8 };

var query = numbers1.Except(numbers2);

foreach (var num in query)
{
    Console.WriteLine(num);
}
  1. 使用LINQ進行集合的連接操作:
var query = from order in dbContext.Orders
            join customer in dbContext.Customers on order.CustomerId equals customer.Id
            select new { OrderId = order.Id, CustomerName = customer.Name };

foreach (var result in query)
{
    Console.WriteLine($"{result.OrderId}, {result.CustomerName}");
}
  1. 使用LINQ進行集合的逆序操作:
int[] numbers = { 1, 2, 3, 4, 5 };

var query = numbers.Reverse();

foreach (var num in query)
{
    Console.WriteLine(num);
}

以上是20個常用的LINQ功能點的示例代碼,它們展示了LINQ在C#中的強大查詢能力和靈活性。通過使用LINQ,開發人員可以更加方便地進行各種數據操作和查詢,提高代碼的可讀性和開發效率。

 


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

-Advertisement-
Play Games
更多相關文章
  • 最近買了本C++20的書,想要自己配置下在VScode的環境 例子代碼: #include <iostream> #include <format> int main() { std::cout << std::format("Hello, world! {0}", 123) << std::end ...
  • 秋招接近尾聲,各大公司基本也陸續開獎了。這裡整理了部分公司的薪資情況,數據來源於 OfferShow 和牛客網。 ps:爆料薪資的幾乎都是 211 和 985 的,並不是刻意只選取學校好的。另外,無法保證數據的嚴格準確性。 淘天 城市:杭州 崗位:演算法 學歷:碩士 985 薪資: 32*16 備註: ...
  • Npcap 是一個功能強大的開源網路抓包庫,它是 WinPcap 的一個分支,並提供了一些增強和改進。特別適用於在 Windows 環境下進行網路流量捕獲和分析。除了支持通常的網路抓包功能外,Npcap 還提供了對數據包的拼合與構造,使其成為實現 UDP 數據包發包的理想選擇。本章將通過Npcap庫... ...
  • 學習視頻:孫哥說SpringMVC:結合Thymeleaf,重塑你的MVC世界!|前所未有的Web開發探索之旅 第一章、SpringMVC的引言 1.1什麼是SpringMVC 概念:SpringMVC是基於Spring Framework衍生而來的MVC框架,主要解決了原有MVC框架開發過程中,控 ...
  • ✨前言✨ 本片文章,主要在於瞭解Calendar類,及對它常用方法的運用 🍒歡迎點贊 👍 收藏 ⭐留言評論 📝私信必回喲😁 🍒博主將持續更新學習記錄收穫,友友們有任何問題可以在評論區留言 @目錄🍊 Calendar類🍊 Calendar類常用方法🍊 Calendar類對象欄位類型🍊 ...
  • 一、前言(整個流程除了調整列印模板位子,操作下來還是挺快的 幾分鐘就搞定,文章圖片比較多大家可能感覺操作比較麻煩,其實挺簡單的) 因甲方需求,需要對現項目進行升級,需要增加移動手持終端進行巡檢,巡檢時還需要對商品進行抽檢並列印熱敏不幹膠標簽進行貼到抽樣樣品上。在這樣的背景下便在JD進行了採樣,進行技 ...
  • Mapster是一個開源的.NET對象映射庫,它提供了一種簡單而強大的方式來處理對象之間的映射。在本文中,我將詳細介紹如何在.NET中使用Mapster,並提供一些實例和源代碼。 和其它框架性能對比: Mapster的安裝和配置: 首先,打開Visual Studio並創建一個新的.NET項目。 在 ...
  • .NET Core MVC基礎之頁面傳值方式📃 前言 最近工作太忙了,淺淺更新一下.NET基礎知識。大部分面試官都會問.NET頁面傳值的幾種方式,那麼接下來就來細講與實現一下吧! 頁面傳值分成兩類 第一類:控制器給視圖傳值 第二類:視圖給控制器傳值 本篇文章主要講控制器給視圖傳值 控制器->視圖 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...