天天看點

C#3.0 LINQ 查詢文法

首先來看一個很簡單的LINQ查詢例子,查詢一個int 數組中小于5的數字,并按照大小順序排列:

class Program

{

    static void Main(string[] args)

    {

        int[] arr = new int[] { 8, 5, 89, 3, 56, 4, 1, 58 };

        var m = from n in arr where n < 5 orderby n select n;

        foreach (var n in m)

        {

            Console.WriteLine(n);

        }

        Console.ReadLine();

    }

}

上述代碼除了LINQ查詢文法外,其他都是我們所熟悉的文法,而LINQ查詢文法跟SQL查詢文法很相識,除了先後順序。

Q:為何 LINQ 查詢文法是以 from 關鍵字開頭的,而不是以 select 關鍵字開頭的?select 開頭這種寫法跟SQL的寫法更接近,更易懂呀?

A:簡單來說,為了IDE的智能感覺(Intelisence)這個功能,select 關鍵字放在後面了。

程式設計語言以 select 開頭寫LINQ查詢文法不是沒出現過,你如果使用過2005年的VB9 CTP 版本,那時候VB9的LINQ查詢文法就是 select 關鍵字在前面,但是 select 關鍵字在前面,在做智能感覺(Intelisence)時候就很頭大。經過微軟IDE組的權衡,确定了把 from 關鍵字放在最前面。

假設你要書寫這樣的代碼:Select p.Name, p.Age From p In persons Where xxx ,代碼是一個個字元輸入的。

我們在寫到 p in persons 之前,p 的類型是無法推測的,是以寫 Select p. 的時候,Name之類的屬性不會彈出智能提示來。

這樣就需要先去寫 From 這句,再回來寫 Select。

微軟IDE組經過反複考慮決定,還不如就把 Select 寫到後面了。于是程式設計語言中的寫法就确定這樣來寫了。

我們再來看一個稍稍複雜的LINQ查詢:

在我們羅列的語言字元串中,我們希望按照字元長短,分類羅列出來,實作代碼如下:

static void Main(string[] args)

    string [] languages = {"Java","C#","C++","Delphi","VB.net","VC.net","C++ Builder","Kylix","Perl","Python"};

    var query = from item in languages

                orderby item

                group item by item.Length into lengthGroups

                orderby lengthGroups.Key descending

                select lengthGroups;

    foreach (var item in query)

        Console.WriteLine("strings of length {0}",item.Key);

        foreach (var val in item)

            Console.WriteLine(val);

    Console.ReadLine();