LINQ查询let子句

  在LINQ查询表达式中,let子句可以创建一个新的范围变量,并且使用该变量保存表达式中的结果。let子句指定的范围变量的值只能通过初始化操作进行赋值,范围变量的值一旦被初始化,将不能再被改变。

  下面的代码实例中的LetQuery()函数演示了let子句查询的方法,具体步骤说明如下。

(1)创建数据类型为List<UserInfo>的数据源users。

(2)使用let子句创建number范围变量,并初始化为用户名称中的序列号。

(3)where子句查询ID值小于9、且用户名称中的序列号(存储在number范围变量中)为偶数的用户。

(4)使用foreach语句输出查询的结果。

private void LetQuery()
         {   ///构建数据源
                   List<UserInfo> users = new List<UserInfo>();
                   for (int i = 1; i < 10; i++)
                   {
                            users.Add(new UserInfo(i,"User0" + i.ToString(),"User0" + i.ToString() + "@web.com"));
                   }
                   ///查询ID值小于9,且序号为偶数的用户
                   var value = from u in users
                                     let number = Int32.Parse(u.Username.Substring(u.Username.Length - 1))
                                     where u.ID < 9 && number % 2 == 0
                                     select u;
                   ///显示查询结果
                   foreach (var v in value)
                   {
                            Response.Write(v.Username + "</br>");
                   }
         }

  运行上述实例代码,在IE浏览器中查看let子句查询的结果,如图所示。

 

来源:http://blog.csdn.net/linqmail/article/details/2302701

加支付宝好友偷能量挖...


评论(0)网络
阅读(152)喜欢(0)asp.net-linq