【C#】LINQ使用

来源:互联网 发布:玫瑰战争 知乎 书 编辑:程序博客网 时间:2024/06/03 20:39

【官方文档】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();        }    }
原创粉丝点击