LINQ入門

来源:https://www.cnblogs.com/bibi-feiniaoyuan/archive/2020/02/22/12347266.html
-Advertisement-
Play Games

記錄LINQ學習過程。 概要 LINQ是一種“語言集成”的查詢表達式,使用LINQ可以智能提示和進行類型檢查。C#里可以編寫的LINQ查詢有SQL資料庫、XML文檔、ADO.NET數據集、支持IEnumerable和IEnumerable的對象。使用LINQ,可以簡單對數據源進行分組、排序、篩選。有 ...


記錄LINQ學習過程。

概要

LINQ是一種“語言集成”的查詢表達式,使用LINQ可以智能提示和進行類型檢查。C#里可以編寫的LINQ查詢有SQL資料庫、XML文檔、ADO.NET數據集、支持IEnumerable和IEnumerable的對象。使用LINQ,可以簡單對數據源進行分組、排序、篩選。有一些第三方庫也為Web服務和其他資料庫提供了LINQ支持。

數組隱式支持了 IEnumerable 介面的。

//尚未執行查詢,等待遍歷再查。 可以在查詢表達式後面添加ToList或ToArray方法,使之立刻查詢。
IEnumerable<int> scoreQuery =           
    from score in new int[] { 97, 92, 81, 60 }
   where score > 90
    select score;

在編譯時,查詢表達式根據 “C# 規範規則”轉換成“標準查詢運算符方法調用”。

在編寫 LINQ 查詢時最好使用查詢語法,必要時可以使用方法調用。

查詢簡介

要想查詢,數據源必須在記憶體中。

//LINQ to XML 將 XML 文檔載入到可查詢的 XElement 類型中:
XElement contacts = XElement.Load(@"c:\myContactList.xml"); 
//LINQ to SQL ,可以手動設計對象關係映射或藉助LINQ TO SQL工具

LINQ和泛型

LINQ引入泛型機制。泛型屬於強類型,不必執行運行時類型轉換,與Object相比,優勢更多。

編譯器可以處理泛型類型聲明,因此可以通過var關鍵字避免使用泛型語法。在LINQ里,是否顯示指定類型並不重要時,例如LINQ分組查詢之後的指定嵌套泛型類型,建議使用var。畢竟晦澀難懂的代碼不太招人喜歡喔!

LINQ基本查詢

篩選,排序

namespace ConsoleApp4
{
    class Program
    {
        static void Main(string[] args)
        {
            IEnumerable<Customer> customers = new List<Customer>() {
            new Customer(){Name="David M. Buss" , City="美國奧斯汀"},
            new Customer(){Name="David M. Buss 1" , City="美國奧斯汀"},
            new Customer(){Name="David M. Buss 2" , City="美國奧斯汀"},
            new Customer(){Name="阿爾弗雷德·阿德勒" , City="英國阿伯丁"},};

            var queryUSCustomers = 
                from customer in customers
                where customer.City == "美國奧斯汀"
                orderby customer.Name ascending  
                select customer;

            foreach(var customer in queryUSCustomers)
            {
                Console.WriteLine(customer.Name);
            }
        }
    }
    class Customer
    {
        public string Name { get; set; }
        public string City { get; set; }
    }
}

David M. Buss
David M. Buss 1
David M. Buss 2

 分組

namespace ConsoleApp4
{
    class Program
    {
        static void Main(string[] args)
        {
            IEnumerable<Customer> customers = new List<Customer>() {
            new Customer(){Name="David M. Buss" , City="美國奧斯汀"},
            new Customer(){Name="David M. Buss 1" , City="美國奧斯汀"},
            new Customer(){Name="David M. Buss 2" , City="美國奧斯汀"},
            new Customer(){Name="阿爾弗雷德·阿德勒" , City="英國阿伯丁"},};

            // queryCustomersByCity is an IEnumerable<IGrouping<string, Customer>>
            var queryCustomersByCity =
                from cust in customers
                group cust by cust.City; //key 就是City

            // customerGroup is an IGrouping<string, Customer>
            //分組類型實現了IEnumerable介面
            foreach (var customerGroup in queryCustomersByCity)
            {
                Console.WriteLine(customerGroup.Key);
                foreach (Customer customer in customerGroup)
                {
                    Console.WriteLine($"    {customer.Name}");
                }
            }
        }
    }
    class Customer
    {
        public string Name { get; set; }
        public string City { get; set; }
    }
}

 關聯

namespace ConsoleApp4
{
    class Program
    {
        static void Main(string[] args)
        {
            IEnumerable<Customer> customers = new List<Customer>() {
            new Customer(){Name="David M. Buss" , City="美國奧斯汀"},
            new Customer(){Name="David M. Buss 1" , City="美國奧斯汀"},           
            new Customer(){Name="阿爾弗雷德·阿德勒" , City="英國阿伯丁"},};

            IEnumerable<City> cities = new List<City>() {
                new City(){Country="美國",CityName="美國奧斯汀"},
                new City(){Country="英國",CityName="英國阿伯丁"},
            };

            var innerJoinQuery =
                from cust in customers
                join city in cities on cust.City equals city.CityName
                select new { Country = city.Country, Customer = cust.Name };
            //匿名類型
          
            foreach (var item in innerJoinQuery)
            {
                Console.WriteLine($"{item.Country},{item.Customer}");               
            }
        }
    }
    class Customer
    {
        public string Name { get; set; }
        public string City { get; set; }
    }
    class City
    {
        public string Country { get; set; }
        public string CityName { get; set; }
    }
}

使用LINQ進行數據轉換

可以對原序列修改,可以在返回值創建新類型。

//Concat合併序列
var peopleInSeattle = (from student in students
                         where student.City == "Seattle"
                         select student.Last)
                  .Concat(from teacher in teachers  
                          where teacher.City == "Seattle"
                          select teacher.Last);

//記憶體中數據結構轉換為xml
var studentsToXML = new XElement("Root",
                from student in students
                let scores = string.Join(",", student.Scores) //存儲子表達式的結果
                select new XElement("student",
                           new XElement("First", student.First),
                           new XElement("Last", student.Last),
                             new XElement("Scores", GetScore(scores)) //調用C#方法
                        ) // end "student"
                    ); // end "Root"

 支持LINQ的C#功能

string[] stringArray = { "aa", "bb", "b", "a" };
            var query = from str in stringArray
                        group str by str[0] into stringGroup
                        orderby stringGroup.Key
                        select stringGroup;

            foreach (var item in query)
            {
                Console.WriteLine($"key:{item.Key }");
                foreach (var item1 in item)
                {
                    Console.WriteLine(item1);
                }
            }
            //不顯示調用構造函數的初始化
            var cust = new Customer { Name = "Mike", Phone = "555-1212" };
            var IncomingOrders = new List<IncomingOrder>();
            var newLargeOrderCustomers = from o in IncomingOrders
                                         where o.OrderSize > 5
                                         select new Customer { Name = o.Name, Phone = o.Phone };
            //等效的方法調用
            var newLargeOrderCustomers1 = IncomingOrders.Where(o => o.OrderSize > 5)
                .Select(y => new Customer { Name = y.Name, Phone = y.Phone });

查詢表達式、var、不顯示調用構造函數的初始化、匿名類型、擴展方法、lambda表達式。

用C#編寫查詢LINQ

namespace ConsoleApp4
{
    class Program
    {        
        static void Main(string[] args)
        {
            // studentQuery2 is an IEnumerable<IGrouping<char, Student>>
            IEnumerable<Student> students = new List<Student> { 
                new Student{Last="aa",First="AA"},
                new Student{Last="bb",First="BB"},
                new Student{Last="bcc",First="BCC"}
            };
            
            //創建查詢
            var studentQuery=
                from student in students
                group student by student.Last[0];

            //執行查詢
            foreach(var item in studentQuery)
            {
                Console.WriteLine($"key:{item.Key}");
                foreach(var item1 in item)
                {
                    Console.WriteLine(item1.Last);
                }
            }

          //使用let引入標識符
           var studentQuery5 =
                from student in students
                let totalScore = student.Scores[0] + student.Scores[1]
                where totalScore / 4 < student.Scores[0]
                select student.Last + " " + student.First; } }
public class Student { public string Last { get; set; } public string First { get; set; } } }

運行結果:
key:a
aa
key:b
bb
bcc

 使用 let 關鍵字,可以存儲表達式結果,存儲結果可以提供方便,也可以避免多次計算來提高性能


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

-Advertisement-
Play Games
更多相關文章
  • 安裝JDK1.8,安裝時會安裝jdk、jre。 如果只是在IDEA中寫寫代碼,安裝完jdk,在IDEA中指定jdk路徑就可以了。 如果要在命令行下執行jdk的命令,比如java、javac,或者要使用tomcat等依賴jdk的,就需要配置jdk的環境變數。 jdk環境變數的配置 1、JAVA_HOM ...
  • PPT導出圖片質量太差?簡單操作直接導出印刷質地圖片 ​ PPT不僅可以用於展示文檔,還可以用於簡單圖片合成處理,同時,PPT文檔還可以全部導出為圖片. 預設情況下,PPT導出的圖片為96DPI,辛苦做的圖片無法適應很多場合的使用。其實,在windows 下只需要一個小小的設置,就可以導出300DP ...
  • 最近在給客戶開發 Azure DevOps Exension, 該擴展中某個功能需要調用使用 .NET Core 3 寫的 Web Api。 在拜讀了 "Authenticating requests to your service" 之後,我給 Web Api 增加了 JWT 認證。 PS: 我沒 ...
  • 本筆記摘抄自:https://www.cnblogs.com/PatrickLiu/p/8242238.html,記錄一下學習過程以備後續查用。 一、引言 今天我們要講行為型設計模式的第十一個模式--解釋器模式,也是面向對象設計模式的最後一個模式。先要說明一下,其實這個模式不是最後一個模 式(按Go ...
  • 1,安裝WinccV7.4並破解: 安裝WinccV7.4SP1. 安裝授權文件---根據提示 安裝免狗驅動,根據提示 安裝SImatic.net v13.2,連接PLC, 首先在同一個區域網裡面,如果是路由器,則可以採用禁用/啟用網路的方法進行讓路由器分配IP地址. 然後在控制面版--->PG..... ...
  • Entity Framework框架提供了幾種開發模式,比如Database First,Model First,Code First。Database First是最老也是應用得最廣泛的一種設計方式。Database First這種方式的設計高度依賴於資料庫中表的結構,根據表及表間的關係來創建模型 ...
  • 首先看 ServiceCollection 的定義 //定義 public class ServiceCollection : IServiceCollection { private readonly List<ServiceDescriptor> _descriptors = new List< ...
  • mssql是.NET的標配,一般使用.NET的人基本都用mssql。 以前mssql只能支持windows平臺,從微軟打出 擁抱開源 的口號開始,mssql的2017 版本,開始支持linux系統。 一開始,我是直接在centos中安裝mssql的,總的來說,比windows快很多。但是現在都使用容 ...
一周排行
    -Advertisement-
    Play Games
  • 概述:本文代碼示例演示瞭如何在WPF中使用LiveCharts庫創建動態條形圖。通過創建數據模型、ViewModel和在XAML中使用`CartesianChart`控制項,你可以輕鬆實現圖表的數據綁定和動態更新。我將通過清晰的步驟指南包括詳細的中文註釋,幫助你快速理解並應用這一功能。 先上效果: 在 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • openGauss(GaussDB ) openGauss是一款全面友好開放,攜手伙伴共同打造的企業級開源關係型資料庫。openGauss採用木蘭寬鬆許可證v2發行,提供面向多核架構的極致性能、全鏈路的業務、數據安全、基於AI的調優和高效運維的能力。openGauss深度融合華為在資料庫領域多年的研 ...
  • 概述:本示例演示了在WPF應用程式中實現多語言支持的詳細步驟。通過資源字典和數據綁定,以及使用語言管理器類,應用程式能夠在運行時動態切換語言。這種方法使得多語言支持更加靈活,便於維護,同時提供清晰的代碼結構。 在WPF中實現多語言的一種常見方法是使用資源字典和數據綁定。以下是一個詳細的步驟和示例源代 ...
  • 描述(做一個簡單的記錄): 事件(event)的本質是一個委托;(聲明一個事件: public event TestDelegate eventTest;) 委托(delegate)可以理解為一個符合某種簽名的方法類型;比如:TestDelegate委托的返回數據類型為string,參數為 int和 ...
  • 1、AOT適合場景 Aot適合工具類型的項目使用,優點禁止反編 ,第一次啟動快,業務型項目或者反射多的項目不適合用AOT AOT更新記錄: 實實在在經過實踐的AOT ORM 5.1.4.117 +支持AOT 5.1.4.123 +支持CodeFirst和非同步方法 5.1.4.129-preview1 ...
  • 總說周知,UWP 是運行在沙盒裡面的,所有許可權都有嚴格限制,和沙盒外交互也需要特殊的通道,所以從根本杜絕了 UWP 毒瘤的存在。但是實際上 UWP 只是一個應用模型,本身是沒有什麼許可權管理的,許可權管理全靠 App Container 沙盒控制,如果我們脫離了這個沙盒,UWP 就會放飛自我了。那麼有沒... ...
  • 目錄條款17:讓介面容易被正確使用,不易被誤用(Make interfaces easy to use correctly and hard to use incorrectly)限制類型和值規定能做和不能做的事提供行為一致的介面條款19:設計class猶如設計type(Treat class de ...
  • title: 從零開始:Django項目的創建與配置指南 date: 2024/5/2 18:29:33 updated: 2024/5/2 18:29:33 categories: 後端開發 tags: Django WebDev Python ORM Security Deployment Op ...
  • 1、BOM對象 BOM:Broswer object model,即瀏覽器提供我們開發者在javascript用於操作瀏覽器的對象。 1.1、window對象 視窗方法 // BOM Browser object model 瀏覽器對象模型 // js中最大的一個對象.整個瀏覽器視窗出現的所有東西都 ...