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();
        }

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

猜你喜欢

转载自blog.csdn.net/Maybe_ch/article/details/87624492