c# LINQ查询方法(1)

LINQ是什么?

Language Integrated Query 语言集成查询
可以使得查询操作通过编程语言自身来表示,而不是嵌入字符串SQL语句。

LINQ主要部分

LINQ to Objects 主要负责对象的查询
LINQ to XML 主要负责XML的查询
LINQ to ADO.NET 主要负责数据库的查询

LINQ查询方法

1.获取数据Select();
Select()方法在时候用的时候,要求传递一个委托实例。
示例

        static void Main(string[] args)
        {
            int[] nums = { 1, 7, 5, 8, 9, 6, 1, 22, 11, 89 };
            var list = nums.Select(k=>k*k);
            foreach(int a in list)
            {
                Console.WriteLine(a);
            }
            Console.ReadKey();
        }

运行结果:
在这里插入图片描述

Select()方法里面是一个Lambda表达式
返回结果是一个迭代器(Iterator)

2.筛选数据:Where()方法
Where()方法是一个扩展泛型方法
Where()方法使用的时候要求传递一个委托示例,但要求该实例是一个判断条件,返回值为bool类型
示例

static void Main(string[] args)
        {
            int[] nums = { 1, 7, 5, 8, 9, 6, 1, 12, 11, 10 };
            var list = nums.Where(k => k % 2 == 0); 
            foreach(int a in list)
            {
                Console.WriteLine(a);
            }
            Console.ReadKey();
        }

运行结果:
在这里插入图片描述
3.排序数据:OrderBy()
OrderBy()是一个扩展方法
OrderBy()里面的参数要求传递一个排序的字段,默认按照升序排列
降序使用OrderByDescending()
示例

 static void Main(string[] args)
        {
            int[] nums = { 1, 7, 5, 8, 9, 6, 1, 12, 11, 10 };
            var list = nums.OrderByDescending(i => i);
            foreach(int a in list)
            {
                Console.WriteLine(a);
            }
            Console.ReadKey();
        }

运行结果
在这里插入图片描述
4.分组数据:GroupBy()方法
GroupBy()里面的参数要求传递一个分组的字段
示例

  static void Main(string[] args)
        {
            string[] nums = {"张三","张四","李一","张五","王七","王十"};
            var list = nums.GroupBy(i => i.Substring(0,1));
            foreach(var a in list)
            {
                Console.WriteLine("分组条件:"+a.Key);
                foreach (var k in a)
                {
                    Console.WriteLine(k);
                }
            }
            Console.ReadKey();
        }

运行结果
在这里插入图片描述

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Maybe_ch

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值