【C#】LINQ使用

【官方文檔】LINQ簡介

class Program
    { 
        static void Main(string[] args)
        {
            string[] names = { "Alonso", "Zheng", "Smith", "Jones", "Smythe", 
                             "Small", "Ruiz", "Hsieh", "Jorgenson", "Ilyich",
                             "Singh", "Samba", "Fatimah"};

            //============================================================================
            ///查詢語法
            ///指定數據源:from in 子句
            ///指定條件:where 子句(可選)
            ///選擇元素:select 子句
            var queryResults1 = from n in names where n.StartsWith("S") select n;

            Console.WriteLine("查詢語法 結果");
            foreach(var item in queryResults1)
            {
                Console.WriteLine(item);
            }
            Console.WriteLine("=====================================================");

            //============================================================================
            ///查詢語法的強制立即執行
            ///要強制立即執行任何查詢並緩存其結果,可調用 ToList 或 ToArray 方法。
            queryResults1 = (from n in names where n.StartsWith("S") select n).ToArray();

            //============================================================================
            ///LINQ拓展方法
            var queryResults2 = names.Where(n => n.StartsWith("S"));
            Console.WriteLine("LINQ拓展方法 結果");
            foreach (var item in queryResults2)
            {
                Console.WriteLine(item);
            }
            Console.WriteLine("=====================================================");

            //============================================================================
            ///排序查詢結果:orderby 子句(可選)
            ///默認爲升序(A~Z),descending 降序關鍵字: orderby n descending
            ///按照最後一個字母排序:orderby n.Substring(n.Length - 1)
            var queryResults3 = from n in names where n.StartsWith("S") orderby n select n;
            Console.WriteLine("排序查詢結果 結果");
            foreach (var item in queryResults3)
            {
                Console.WriteLine(item);
            }
            Console.WriteLine("=====================================================");
            ///多級排序(適用於帶多個屬性的對象)
            ///Orderby c.Region, c.Country,c.City

            //============================================================================
            ///聚合運算符
            ///Min(),MAx(),Average(),Sum
            Console.WriteLine("返回結果個數:" + queryResults3.Count());
            Console.WriteLine("=====================================================");

            //============================================================================
            ///單值選擇查詢
            ///去除重複值
            var queryResults4 = (from n in names select n).Distinct();
            queryResults4.Select(n => n).Distinct();

            Console.ReadKey();
        }
    }
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章