linq中let
类别:编程学习 浏览量:1057
时间:2014-9-19 linq中let
linq中letlinq中let关键字就是对子查询的一个别名,let子句用于在查询中添加一个新的局部变量,使其在后面的查询中可见。
linq中let关键字实例
1、传统下的子查询与LET关键字的区别
static void Main(string[] args)
{
int[] numbers = new[] { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
//传统下的子查询做法
var query = from num in numbers
select num * (from n in numbers
where n % 2 == 0
select n).Count();
//使用LET关键字的做法
var query = from num in numbers
let evenNumbers = from n in numbers
where n % 2 == 0
select n
select num * evenNumbers.Count();
foreach (var item in query)
{
Console.WriteLine(item);
}
Console.Read();
}
2、把每个单词开头包含a或者e的找出来
using System;
using System.Linq;
public class Test
{
static void Main(string[] args)
{
string[] strings = { "A penny saved is a penny earned.", "The aaxly sdj", "the pa is no" };
var query = from sentence in strings
let words = sentence.Split(' ')//用空格分割成数组
from word in words
let w = word.ToLower()//把每个字母小写
where w[0] == 'a' || w[0] == 'e'
select word;
foreach (var s in query)
{
Console.WriteLine(s);
}
Console.ReadLine();
}
}
3、linq实例3
var query = from p in persons
let friendlyName = p.Gender == "男" ? "Mr" : "Ms" + p.Name
select new
{
UserID = p.ID,
FriendName = friendlyName
};
foreach (var item in query)
{
Console.WriteLine("No:{0},Friendly Name:{1}", item.UserID, item.FriendName);
}
4、linq实例4
public class Singer
{
public string Name { set; get; }
public int Age { set; get; }
}
List<Singer> list = new List<Singer>(){
new Singer{Name="zhangs" ,Age=21},
new Singer{Name="zhangs",Age=25},
new Singer{Name="margy",Age=21}
};
var query = from a in list
let b = a.Name
let c=a.Age
where b =="zhangs" & c>21
select a;
foreach (var item in query)
{
Response.Write("姓名: "+item.Name+" 年龄:"+item.Age);
}
//结果 姓名: zhangs 年龄:25
//使用let 建立了个范围变量,这个范围变量在后续的where子句中使用,如果不使用let子句,where子句的表达式将写成这样:
//where a.Name=="zhangs" & a.Age>21</span>
标签:linq
您可能感兴趣
- linq xml 查询
- linq中group by
- linq中join用法
- Linq中select查询
- linq中let
- linq to sql 中Concat、Union、Intersect、Except
- LINQ TO SQL 中join
- linq distinct去重
- LINQ中Aggregate的用法
- datatable linq查询
- linq 数据类型转换
- 如何查看linq生成的sql
- linq中延迟执行
- Linq中的TakeWhile和SkipWhile
- Linq中where查询
- linq not in 查询
- 34岁的舒畅,就这样走到了末路,不知会不会后悔15年前的草率决定(就这样走到了末路)
- 不走心的古装造型 舒畅 毁容式 出演,萧蔷雷出新高度(不走心的古装造型)
- 嘉南传 第22集(嘉南传第22集)
- 哪版孙悟空最萌 黄渤躺萌了(哪版孙悟空最萌)
- 融入小人物的喜怒哀乐,黄渤饰演的角色为什么让人观看时欲罢不能(融入小人物的喜怒哀乐)
- 《极限挑战》深访都市夜归人,夜间打工者体验,黄磊录完憔悴了(极限挑战深访都市夜归人)
热门推荐
- linux下启动tomcat服务(Linux系统安装Tomcat并配置Service启动关闭)
- mysql 自定义排序
- Sql的decimal、float、double类型的区别
- pyqt左侧菜单栏(pyside+pyqt实现鼠标右键菜单功能)
- css position详解(深究CSS定位position的常用技法)
- linux系统各种执行命令(Linux调整命令历史方法详解)
- python停止执行的代码(python定时检测无响应进程并重启的实例代码)
- 如何看云服务器日志(云服务器怎么查看日志的步骤)
- tick数据间隔时间为2秒(让你一看就明白的$nextTick讲解)
- sqlserver完全删除教程(sql server编写archive通用模板脚本实现自动分批删除数据)