LINQ查询表达式---------join子句
LINQ查询表达式---------join子句
join 子句接受两个源序列作为输入。 每个序列中的元素都必须是可以与另一个序列中的相应属性进行比较的属性,或者包含一个这样的属性。 join子句使用特殊的 equals 关键字比较指定的键是否相等。 join 子句执行的所有联接都是同等联接。 join 子句的输出形式取决于所执行的联接的具体类型。 以下是三种最常见的联接类型:
内部联接
分组联接
左外部联接
- class Program
- {
- public class PerInfo
- {
- public int Id
- {
- get;
- set;
- }
- public string Name
- {
- get;
- set;
- }
- public int Age
- {
- get;
- set;
- }
- }
- public class CustInfo
- {
- public int PerId
- {
- get;
- set;
- }
- public string Tel
- {
- get;
- set;
- }
- public string Email
- {
- get;
- set;
- }
- }
- static void Main(string[] args)
- {
- List<PerInfo> perinfos = new List<PerInfo>
- {
- new PerInfo{Id = , Name = "小白", Age = },
- new PerInfo{Id = , Name = "小日", Age = },
- new PerInfo{Id = , Name = "小月", Age = },
- new PerInfo{Id = , Name = "小明", Age = }
- };
- List<CustInfo> custInfos = new List<CustInfo>
- {
- new CustInfo{PerId = , Tel = "153******", Email = "123@qq.com"},
- new CustInfo{PerId = , Tel = "153****11", Email = "321@qq.com"},
- new CustInfo{PerId = , Tel = "134******", Email = "112@qq.com"},
- new CustInfo{PerId = , Tel = "134****11", Email = "211@qq.com"},
- new CustInfo{PerId = , Tel = "125******", Email = "134@qq.com"},
- new CustInfo{PerId = , Tel = "125****11", Email = "431@qq.com"}
- };
- //1、内部联接
- var query1 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId
- select new { NewName = p.Name, NewTel = c.Tel, NewEmail = c.Email };
- Console.WriteLine("内部联接:");
- foreach (var item in query1)
- {
- Console.WriteLine(" {0} {1} {2}", item.NewName, item.NewTel, item.NewEmail);
- }
- //2、分组联接_01
- var query2 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId into groupquery
- select new { NewName = p.Name, NewQuery = groupquery };
- Console.WriteLine("\n分组联接_01");
- foreach (var v in query2)
- {
- Console.WriteLine("{0}", v.NewName);
- foreach (var item in v.NewQuery)
- {
- Console.WriteLine(" {0} {1}", item.Tel, item.Email);
- }
- }
- //3、分组联接_02
- var query3 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId into groupquery
- select groupquery;
- Console.WriteLine("\n分组联接_02");
- foreach (var v in query3)
- {
- foreach (var item in v)
- {
- Console.WriteLine(" {0} {1} {2}", item.PerId, item.Tel, item.Email);
- }
- }
- //4、分组联接_03
- var query4 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId into groupquery
- select new
- {
- NewName = p.Name,
- NewQuery = from q in groupquery
- where q.PerId >
- orderby q.Email descending
- select q
- };
- Console.WriteLine("\n分组联接_03");
- foreach (var v in query4)
- {
- Console.WriteLine("{0}", v.NewName);
- foreach (var item in v.NewQuery)
- {
- Console.WriteLine(" {0} {1} {2}", item.PerId, item.Tel, item.Email);
- }
- }
- //5、左外联接_01
- var query5 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId into groupquery
- select groupquery.DefaultIfEmpty(new CustInfo()
- {
- PerId = p.Id, Tel = "Nothing", Email = "Nothing"
- });
- Console.WriteLine("\n左外联接_01");
- foreach (var v in query5)
- {
- foreach (var item in v)
- {
- Console.WriteLine(" {0} {1} {2}", item.PerId, item.Tel, item.Email);
- }
- }
- // 6、左外联接_02
- var query6 = from p in perinfos
- join c in custInfos on p.Id equals c.PerId into groupquery
- from item in groupquery.DefaultIfEmpty()
- select new { Email = item == null ? "Nothing!" : item.Email, ID = p.Id };
- Console.WriteLine("\n左外联接_02");
- foreach (var v in query6)
- {
- Console.WriteLine(" {0} {1} ", v.ID, v.Email);
- }
- Console.ReadLine();
- }
- }
- 输出结果:
- 内部联接:
- 小白 153****** 123@qq.com
- 小白 153****11 321@qq.com
- 小日 134****** 112@qq.com
- 小日 134****11 211@qq.com
- 小明 125****** 134@qq.com
- 小明 125****11 431@qq.com
- 分组联接_01
- 小白
- 153****** 123@qq.com
- 153****11 321@qq.com
- 小日
- 134****** 112@qq.com
- 134****11 211@qq.com
- 小月
- 小明
- 125****** 134@qq.com
- 125****11 431@qq.com
- 分组联接_02
- 1 153****** 123@qq.com
- 1 153****11 321@qq.com
- 2 134****** 112@qq.com
- 2 134****11 211@qq.com
- 4 125****** 134@qq.com
- 4 125****11 431@qq.com
- 分组联接_03
- 小白
- 小日
- 2 134****11 211@qq.com
- 2 134****** 112@qq.com
- 小月
- 小明
- 4 125****11 431@qq.com
- 4 125****** 134@qq.com
- 左外联接_01
- 1 153****** 123@qq.com
- 1 153****11 321@qq.com
- 2 134****** 112@qq.com
- 2 134****11 211@qq.com
- 3 Nothing Nothing
- 4 125****** 134@qq.com
- 4 125****11 431@qq.com
- 左外联接_02
- 1 123@qq.com
- 1 321@qq.com
- 2 112@qq.com
- 2 211@qq.com
- 3 Nothing!
- 4 134@qq.com
- 4 431@qq.com
LINQ查询表达式---------join子句的更多相关文章
- LINQ查询表达式---------select子句
LINQ查询表达式---------select子句 1.1常见的select子句查询 class Program { public class PerInfo { public int Id { g ...
- LINQ查询表达式---------from子句
LINQ查询表达式---------from子句 LINQ的查询由3基本部分组成:获取数据源,创建查询,执行查询. //1.获取数据源 List<, , , , , }; //创建查询 var ...
- LINQ查询表达式---------let子句
LINQ查询表达式---------let子句 let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它.此范围变量可以再后续的LINQ子句中使用. class P ...
- LINQ查询表达式---------orderby子句
LINQ查询表达式---------orderby子句 LINQ可以按元素的一个或多个属性对元素进行排序. class Program { public class PerInfo { public ...
- LINQ查询表达式---------group子句
LINQ查询表达式---------group子句 LINQ表达式必须以from子句开头,以select或group子句结束.使用guoup子句来返回元素分组后的结果.group 子句返回一个 IGr ...
- LINQ查询表达式---------where子句
LINQ查询表达式---------where子句 where 子句用在查询表达式中,用于指定将在查询表达式中返回数据源中的哪些元素. 它将一个布尔条件(“谓词”)应用于每个源元素(由范围变量引用), ...
- 2.3 LINQ查询表达式中 使用select子句 指定目标数据
本篇讲解LINQ查询的三种形式: 查询对象 自定义查询对象某个属性 查询匿名类型结果 [1.查询结果返回集合元素] 在LINQ查询中,select子句和from子句都是必备子句.LINQ查询表达式必须 ...
- LINQ查询表达式---------into
LINQ查询表达式---------into into 上下文关键字创建一个临时标识符,以便将 group.join 或 select 子句的结果存储到新的标识符 class Program { pu ...
- LINQ查询表达式(1) - 查询表达式基础
LINQ包括五个部分:LINQto Objects.LINQ to DataSets.LINQ to SQL.LINQ to Entities.LINQ to XML. 什么是查询?它有什么用途? “ ...
随机推荐
- [Ramda] Create a Query String from an Object using Ramda's toPairs function
In this lesson, we'll use Ramda's toPairs function, along with map, join, concatand compose to creat ...
- php课程 4-14 数组如何定义使用
php课程 4-14 数组如何定义使用 一.总结 1.各种语言键值对取值和赋值赋值表达式左边的特点是什么? 键值对,用于取值和赋值,取值和赋值的左边都是一样的 2.各种语言键值对取值或者赋值的时候如 ...
- HDU 4870 Rating 高斯消元法
链接:http://acm.hdu.edu.cn/showproblem.php?pid=4870 题意:用两个账号去參加一种比赛,初始状态下两个账号都是零分,每次比赛都用分数低的账号去比赛.有P的概 ...
- Python 库的使用 —— dis
dis:Disassembler of Python byte code into mnemonics. Java.Python.Ruby 1.9 这些语言均使用了栈机器型的 VM.因为是基于栈的实现 ...
- 在向server发送请求时发生传输级错误。 (provider: 共享内存提供程序, error: 0 - 管道的还有一端上无不论什么进程。
作者:卿笃军 原文地址:http://blog.csdn.net/qingdujun/article/details/36425825 SQL Server 2008 + VS2010 用C#编写的代 ...
- sparksql dataset
java /** *2.0之后使用sparksession即可,不需要再去创建sqlcontext *@author Tele * */ public class Demo { private sta ...
- C#与西门子PLC通讯
1.0 通讯组件概述 通讯组件用于PC与可编程控制器(PLC).智能仪表等进行数据通讯,适用于基于PC高级语言的工业自动化控制系统.组件采用动态链接库文件(*.DLL)的形式,在PC系统的项目工程里 ...
- 浅析JAVA的垃圾回收机制(GC)
1.什么是垃圾回收? 垃圾回收(Garbage Collection)是Java虚拟机(JVM)垃圾回收器提供的一种用于在空闲时间不定时回收无任何对象引用的对象占据的内存空间的一种机制. 注意:垃圾回 ...
- 自定义WPF 窗口样式
原文:自定义WPF 窗口样式 Normal 0 false 7.8 pt 0 2 false false false EN-US ZH-CN X-NONE 自定义 Window 在客户端程序中,经常需 ...
- 机器学习: Python with Recurrent Neural Network
之前我们介绍了Recurrent neural network (RNN) 的原理: http://blog.csdn.net/matrix_space/article/details/5337404 ...