在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子句查询的结果,如图所示。