網(wǎng)站首頁 編程語言 正文
SelectMany操作符提供了將多個(gè)from子句組合起來的功能,相當(dāng)于數(shù)據(jù)庫中的多表連接查詢,它將每個(gè)對象的結(jié)果合并成單個(gè)序列。
示例:
student類:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace SelectMany操作符 { ////// 學(xué)生類 /// public class Student { //姓名 public string Name { get; set; } //成績 public int Score { get; set; } //構(gòu)造函數(shù) public Student(string name, int score) { this.Name = name; this.Score = score; } } }
teacher類:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace SelectMany操作符 { ////// Teacher類 /// public class Teacher { //姓名 public string Name { get; set; } //學(xué)生集合 public ListStudents { get; set; } public Teacher(string name, List students) { this.Name = name; this.Students = students; } } }
Program類
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks; namespace SelectMany操作符 { class Program { static void Main(string[] args) { //使用集合初始化器初始化Teacher集合 Listteachers = new List { new Teacher("徐老師", new List (){ new Student("宋江",80), new Student("盧俊義",95), new Student("朱武",45) } ), new Teacher("姜老師", new List (){ new Student("林沖",90), new Student("花榮",85), new Student("柴進(jìn)",58) } ), new Teacher("樊老師", new List (){ new Student("關(guān)勝",100), new Student("阮小七",70), new Student("時(shí)遷",30) } ) }; //問題:查詢Score小于60的學(xué)生 //方法1:循環(huán)遍歷、會有性能的損失 foreach (Teacher t in teachers) { foreach (Student s in t.Students) { if (s.Score < 60) { Console.WriteLine("姓名:" + s.Name + ",成績:"+s.Score); } } } //查詢表達(dá)式 //方法2:使用SelectMany 延遲加載:在不需要數(shù)據(jù)的時(shí)候,就不執(zhí)行調(diào)用數(shù)據(jù),能減輕程序和數(shù)據(jù)庫的交互,可以提供程序的性能,執(zhí)行循環(huán)的時(shí)候才去訪問數(shù)據(jù)庫取數(shù)據(jù) //直接返回學(xué)生的數(shù)據(jù) var query = from t in teachers from s in t.Students where s.Score < 60 select s; foreach (var item in query) { Console.WriteLine("姓名:" + item.Name + ",成績:"+item.Score); } //只返回老師的數(shù)據(jù) var query1 = from t in teachers from s in t.Students where s.Score < 60 select new { t, teacherName=t.Name, student=t.Students.Where(p=>p.Score<60).ToList() }; foreach (var item in query1) { Console.WriteLine("老師姓名:" + item.teacherName + ",學(xué)生姓名:" +item.student.FirstOrDefault().Name+ ",成績:" + item.student.FirstOrDefault().Score); } // 使用匿名類 返回老師和學(xué)生的數(shù)據(jù) var query2 = from t in teachers from s in t.Students where s.Score < 60 select new { teacherName=t.Name, studentName=s.Name,studentScore=s.Score }; foreach (var item in query2) { Console.WriteLine("老師姓名:" + item.teacherName + ",學(xué)生姓名:" + item.studentName + ",成績:" + item.studentScore); } //使用查詢方法 var query3 = teachers.SelectMany(p => p.Students.Where(t=>t.Score<60).ToList()); foreach (var item in query3) { Console.WriteLine("姓名:" + item.Name + ",成績:" + item.Score); } Console.ReadKey(); } } }
原文鏈接:https://www.cnblogs.com/dotnet261010/p/6849980.html
相關(guān)推薦
- 2021-12-28 Android中實(shí)現(xiàn)視差滾動示例介紹_Android
- 2022-06-02 Python學(xué)習(xí)之隨機(jī)模塊random詳解_python
- 2021-12-01 Linux五步構(gòu)建內(nèi)核樹_Linux
- 2023-01-05 Go單例模式與Once源碼實(shí)現(xiàn)_Golang
- 2022-10-11 oracle 12c和plsql的詳細(xì)安裝和配置過程(超級詳細(xì),小白也能懂)
- 2022-06-23 Python+Turtle制作獨(dú)特的表白圖_python
- 2022-12-21 C語言中continue的用法詳解_C 語言
- 2023-03-15 pandas創(chuàng)建DataFrame對象失敗的解決方法_python
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支