当前位置: 首页 > 工具软件 > LINQ4Obj-C > 使用案例 >

LINQ(4)——Linq To Object

贝礼骞
2023-12-01

查询语句:

 int[] values = { 30, 5, 99, 77, 102, 8, 12, 35 };
            var result = from item in values //foreach(int item in values)
                         where item > 20
                         select item;

和sql语句不同,linq中select放到最后(方便类型推断)。in后是要进行处理的集合,from后的变量是values中每个元素的变量(联想foreach),select后是查询结果,result是select结果变量类型的泛型的IEnumerable,注意是泛型的IEnumerable 。linq关键时刻能救人一命。

练习:

1、从字符串数组中将长度小于5的元素返回;

2、一个字符串数组中所有元素都是整数的表示形式,将他们中大于100的以int序列返回;{"1","25","250","388","99"}

3、将一个姓名为Key、年龄为value的Dictionary中年龄大于20的人的姓名用“,”分割打印出来。//ToArray(),Join

4、将 "ajax,javascript,jquery"字段中的单词加上【】输出出来。select “[”+item+”]”

5、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人依次输出到含有Name、Age属性的匿名类型的序列中。select new {}

6、一个Dictionary<string,int>中是key为姓名,value为年龄的数据,将其中年龄大于20的人输出到含有Name、Age属性的预定义类型Person的序列中。

int[] values = { 3, 5, 9, 8, 2, 20, -5, -9, 306 };
            values.OrderBy(i => i);
            //过滤掉负数,把数组排序,然后元素两边加[]输出
            IEnumerable<int> e1= values.Where(i => i > 0);
            var e1 = values.Where(i => i > 0);
            foreach (int i in e1)
            {
                Console.WriteLine(i);
            }

            //=========================进化=========

            var e1 = values.Where(i => i > 0).OrderBy(i => i)
                .Select(i=>"["+i+"]");
            foreach (var i in e1)
            {
                Console.WriteLine(i);
            }

            //================进化:微软V5,效率更高更清晰=========
            //
            //执行顺序是从上到下
            var e1 = from i in values//foreach(int i in values)
                     where i>0
                     orderby i descending
                     select "[" + i + "]";
            //基于类型推断的考虑,select在最后,from在最前
            foreach (var i in e1)
            {
                Console.WriteLine(i);
            }

            //根据一个DBPerson对象,过滤出年龄大于20的人,按照年龄排序
            //并且根据FirstName、LastName拼出Name

 类似资料: