【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();
        }
    }
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值