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. 什么是查询?它有什么用途? “ ...
随机推荐
- java基础—网络编程———建立聊天的形式
接收器和发射器的简单演示 import java.io.*; import java.net.*; public class SocketDemo { public static void main( ...
- 192M内存的VPS,安装Centos 6 minimal x86,无法安装node.js
尝试了各种方法,始终安装不了node.偶然一次,安装了64位的Centos 6 minimal,竟然可以安装Node官网给出的命令安装node了,一切顺利.
- 利用jQuery传送json格式的字符串,后端用ashx文件来接收
在Default.aspx里面,我们会透过javascript建立两个物件,分别有Name和Age的属性,再透过Array的方式,将这两个物件塞到Array里面去.使用Ajax内建的$.ajax AP ...
- Facebook学长交流分享
印象中这似乎是 Facebook 第一次来浙大校园做交流. 前不久,也参加了 Google 的校园宣讲,G 的两大宣讲主题是 Google 介绍和模拟面试.印象最深的是无敌的一家三口每年 100w 封 ...
- Java 开源博客——B3log Solo 0.6.5 正式版发布了!
Java 开源博客 -- B3log Solo 0.6.5 正式版发布了!欢迎大家下载. 该版本主要是改善细节体验,也是 B3log Solo 的最后一个大版本. 这个版本发布后,B3log Solo ...
- javascript对象属性为空的判断
zepto: $.isEmptyObject = function(obj) { var name for (name in obj) return false return true } $.isE ...
- QT调用VC DLL的例子(所有源码)
http://blog.csdn.net/zhuce0001/article/details/20651025 http://blog.csdn.net/zhuce0001/article/detai ...
- Java文件运用
1.使用java修改文件内容: package fileopt; import java.io.BufferedReader; import java.io.BufferedWriter; impor ...
- Python 实现 淘宝秒杀 聚划算 自己主动提醒 源代码
说明 本实施例可以监视一起购买的成本button,当警报济济一堂花费时间整点到达(音频文件自定义位置)而自己主动跳出页面(URL习惯). 同一时候还能够通过命令行參数自己定义刷新间隔时间(默认0.1s ...
- WPF 遍历DataTemplate(获取所有控件)
原文:WPF 遍历DataTemplate(获取所有控件) 情况1:在设定DataTemplate的Name,并且他是在前台表示时,获取DataTemplate里的指定控件. 方法: http://b ...