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. 什么是查询?它有什么用途? “ ...
随机推荐
- xCode中怎样保存自己的代码块
在开发iOS的过程中.xCode肯定是用得最多的工具.没有之中的一个.由于苹果官方提供的就这一个平台,尽管没有竞争对手,但秉承苹果一贯的注重细节的原则,xCode还是一款相当不错的IDE. 作为一名i ...
- shell判断和比较
http://blog.chinaunix.net/uid-7553302-id-183648.html 1 shell 的$! ,$?, $$,$@ $n $1 the first ...
- Expression Blend 的点滴(4)--创建类似iPhone屏幕锁控件(上)
原文:Expression Blend 的点滴(4)--创建类似iPhone屏幕锁控件(上) 本篇文章,最终效果图: 当然,不只是一个UI而已,如果只是一张图片,那专业的设计师能做出更出色的效果.在 ...
- 华为云软件开发云:容器DevOps,原来如此简单!
当开发团队把代码提交到 Git 应用仓库的那一刻,他们心里在想什么? 祈祷没有bug?渴望回家补觉?产品经理Go Die? 对,也不对.因为这只是最终发布万里长征的一小步,接下来要面对测试环境.生产环 ...
- 【19.27%】【codeforces 618D】Hamiltonian Spanning Tree
time limit per test2 seconds memory limit per test256 megabytes inputstandard input outputstandard o ...
- Linux 下的任务管理 —— ps、top
ps:report a snapshot of the current processes. ps 命令支持三种使用的语法格式 UNIX 风格,选项可以组合在一起,并且选项前必须有"-&qu ...
- C#中的Lambda总结
Lambda的前世今生 早在C# 1.0 时,C#中就引入了委托(delegate)类型的概念.通过使用这个类型,我们可以将函数作为参数进行传递.在某种意义上,委托可理解为一种托管的强类型的函数指针. ...
- net平台的rabbitmq
net平台的rabbitmq使用封装 前言 RabbitMq大家再熟悉不过,这篇文章主要整对rabbitmq学习后封装RabbitMQ.Client的一个分享.文章最后,我会把封装组件和demo奉上. ...
- NoSQL Manager for MongoDB 破解
删除这两个地方的东西就好了 运行 -->regedit HKEY_CURRENT_USER\Software\NoSQL Manager Group 删除该文件夹 C:\ProgramData\ ...
- prism behavior图示
原文:prism behavior图示 怕以后丢失,还是发一下,看起来可能会比较乱