寻找薛定谔的猫

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
统计
 

let子句用于在LINQ表达式中存储子表达式的计算结果。let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它。
此范围变量可以再后续的LINQ子句中使用。

实例1

复制代码
 1 int[] numbers = new[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9 };
 2 
 3 //传统下的子查询做法
 4 //var query = from num in numbers
 5 //            select num * (from n in numbers
 6 //                          where n % 2 == 0
 7 //                          select n).Count();
 8 
 9 //使用LET关键字的做法
10 var query = from num in numbers
11          let evenNumbers = from n in numbers
12                     where n % 2 == 0
13                          select n
14         select num * evenNumbers.Count();
15 
16 foreach (var item in query)
17 {
18     Console.WriteLine(item);
19 } 
复制代码

运行结果:0 5 10 15 20 25 30 35 40 45

实例2

复制代码
 1 string[] strings = { "A penny saved is a penny earned.", "The aaxly sdj", "the pa is no" };
 2 
 3 var query = from sentence in strings
 4             let words = sentence.Split(' ')//用空格分割成数组                
 5             from word in words
 6             let w = word.ToLower()//把每个字母小写        
 7             where w[0] == 'a' || w[0] == 'e'
 8             select word;
 9 
10 foreach (var s in query)
11 {
12     Console.WriteLine(s);
13 }
复制代码

 

运行结果:

实例3

复制代码
 1 List<Person> persons = new List<Person>
 2 {
 3     new Person { ID = "0001", Name = "张三" ,Gender = "" , Age = 18},
 4     new Person { ID = "0002", Name = "李四" ,Gender = "" , Age = 17},
 5     new Person { ID = "0003", Name = "王五" ,Gender = "" , Age = 19},
 6     new Person { ID = "0004", Name = "赵六" ,Gender = "", Age = 20}
 7 };
 8 var query = from p in persons
 9             let friendlyName = p.Gender == "" ? "Mr" + p.Name : "Ms" + p.Name
10             select new
11             {
12                 UserID = p.ID,
13                 FriendName = friendlyName
14             };
15 foreach (var item in query)
16 {
17     Console.WriteLine("No:{0},Friendly Name:{1}", item.UserID, item.FriendName);
18 }
复制代码

运行结果:

 实例4

复制代码
 1 List<Person> persons = new List<Person>
 2 {
 3     new Person { ID = "0001", Name = "张三" ,Gender = "" , Age = 18},
 4     new Person { ID = "0002", Name = "李四" ,Gender = "" , Age = 17},
 5     new Person { ID = "0003", Name = "王五" ,Gender = "" , Age = 19},
 6     new Person { ID = "0004", Name = "赵六" ,Gender = "", Age = 20}
 7 };
 8 
 9 var query = from p in persons
10             let gender = p.Gender
11             let age = p.Age
12             where age > 18 && gender == ""
13             select p;
14 foreach (var item in query)
15 {
16     Console.WriteLine("姓名: " + item.Name + "  年龄:" + item.Age);
17 }
复制代码

运行结果:

posted on   teagueli  阅读(2272)  评论(0编辑  收藏  举报
编辑推荐:
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
 
点击右上角即可分享
微信分享提示