linq之join子句
前面我们总结Linq查询子句总共有8个,join子句是我们讲解的最后一个子句。join子句也是相对比较复杂的,所以最后来讲。join子句可以处理两个数据源之间的联系,当然这两个数据源之间必须存在相关联的值。
join子句可以实现3中连接关系
1.内部联接:元素的联接关系必须同时满足被连接的两个数据源
2.分组联接:含有into子句的join子句
3.左外部联接
下面我们就详细的分析一下这三种联接方式。
准备数据:
除了前面用到的UserBaseInfo类,我们新增一个roles类:
using System;
using System.Data;
using System.Configuration;
using System.Linq;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.HtmlControls;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Xml.Linq;
using System.Collections;
using System.Collections.Generic; namespace LinqQueryDemo
{
/// <summary>
/// 角色的基本信息
/// </summary>
public class RoleInfo
{
private int id;
private string roleName; /// <summary>
/// 角色的ID值
/// </summary>
public int ID
{
get { return id; }
set { id = value; }
}
/// <summary>
/// 角色的名称
/// </summary>
public string RoleName
{
get { return roleName; }
set { roleName = value; }
} public RoleInfo(int id, string roleName)
{
this.id = id;
this.roleName = roleName;
}
}
}
内部联接
内部联接和sqlserver中的inner join类似,联接关系必须同时满足两个被联接的数据源。下面代码中的InnerJoinQuery方法演示了内部联接users和roles数据源的查询方法。
private void InnerJoinQuery()
{ List<UserBaseInfo> users = new List<UserBaseInfo>();
List<RoleInfo> roles = new List<RoleInfo>(); for (int i = ; i < ; i++)
{
users.Add(new UserBaseInfo(i, "users0" + i.ToString(), "user0" + i.ToString() + "@web.com", i * ));
roles.Add(new RoleInfo(i, "RoleName0" + i.ToString()));
} //查询ID值小于9,且角色包含roles中的用户
var result = from u in users
join r in roles on u.RoleId equals r.ID where u.ID <
select u; foreach (var u in result)
{ Response.Write(u.UserName + "</br>"); }
}
查询结果:
分组联接
含有into子句的join子句被分组连接。分组联接产生分层数据结构。它将第一个集合中的每个元素与第二个集合中的元素进行匹配,在查询结果中,第一个集合中的元素都会出现,第二个集合中的元素如果匹配成功,则使用被找到的元素否则为空。
下面的groupjoinquery函数演示分组联接。
private void GroupJoinQuery()
{ List<UserBaseInfo> users = new List<UserBaseInfo>();
List<RoleInfo> roles = new List<RoleInfo>(); for (int i = ; i < ; i++)
{
users.Add(new UserBaseInfo(i, "users0" + i.ToString(), "user0" + i.ToString() + "@web.com", i * ));
roles.Add(new RoleInfo(i, "RoleName0" + i.ToString()));
} //查询ID值小于9,且角色包含roles中的用户
var result = from u in users
join r in roles on u.RoleId equals r.ID into g where u.ID <
select new
{
ID = u.ID,
UserName = u.UserName,
Email = u.Email,
RoleId = u.RoleId,
Roles = g.ToList()
};
foreach (var u in result)
{ Response.Write(u.UserName +","+(u.Roles.Count>?u.Roles[].RoleName:string.Empty)+ "</br>"); }
}
查询结果:
左外部联接
左外部联接跟sqlserver中的left join相似。他返回第一个集合中的所有元素,第二个集合中与第一个集合相关的元素显示。如果第二个集合中没有找到相关的元素,就用DefaultEmpty方法来指定默认值。
private void LeftOuterJoinQuery()
{ List<UserBaseInfo> users = new List<UserBaseInfo>();
List<RoleInfo> roles = new List<RoleInfo>(); for (int i = ; i < ; i++)
{
users.Add(new UserBaseInfo(i, "users0" + i.ToString(), "user0" + i.ToString() + "@web.com", i * ));
roles.Add(new RoleInfo(i, "RoleName0" + i.ToString()));
} //查询ID值小于9,且角色包含roles中的用户
var result = from u in users
where u.ID <
join r in roles on u.RoleId equals r.ID into gr
from ur in gr.DefaultIfEmpty()
select new
{
ID = u.ID,
UserName = u.UserName,
Email = u.Email,
RoleId = u.RoleId,
Roles = gr.ToList()
};
foreach (var u in result)
{ Response.Write(u.UserName +","+(u.Roles.Count>?u.Roles[].RoleName:string.Empty)+ "</br>"); }
}
运行结果:
linq之join子句的更多相关文章
- LINQ查询表达式---------join子句
LINQ查询表达式---------join子句 join 子句接受两个源序列作为输入. 每个序列中的元素都必须是可以与另一个序列中的相应属性进行比较的属性,或者包含一个这样的属性. join子句使用 ...
- 用Join子句进行分组联接
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.T ...
- C# join子句
join 子句可用于将来自不同源序列并且在对象模型中没有直接关系的元素相关联. 唯一的要求是每个源中的元素需要共享某个可以进行比较以判断是否相等的值. 例如,食品经销商可能拥有某种产品的供应商列表以及 ...
- join 子句(C# 参考)
参考:https://msdn.microsoft.com/zh-cn/library/vstudio/bb311040%28v=vs.110%29.aspx 使用 join 子句可以将来自不同源序列 ...
- LINQ-let子句、join子句
1.Let子句 let子句用于在LINQ表达式中存储子表达式的计算结果,既let子句创建一个范围变量来存储结果,变量被创建后,不能修改或把其他表达式的结果重新赋值给它.此范围变量可以在后续的LINQ中 ...
- Linq之select子句
在Linq中select子句用来指定查询结果的类型和表现形式.Linq查询要么以select子句结尾,要么以group子句结尾. List<UserBaseInfo> users = ne ...
- Linq中join & group join & left join 的用法
Linq中join & group join & left join 的用法 2013-01-30 11:12 12154人阅读 评论(0) 收藏 举报 分类: C#(14) 文章 ...
- MySQL INNER JOIN子句介绍
MySQL INNER JOIN子句介绍 MySQL INNER JOIN子句将一个表中的行与其他表中的行进行匹配,并允许从两个表中查询包含列的行记录. INNER JOIN子句是SELECT语句的可 ...
- C# LinQ的基本子句、协变与异变
//1.from 子句: , , , , , , , , , }; var query = from n in arr select n; foreach (var i in query) { Con ...
随机推荐
- jackson 注脚学习参考
(1)初级我们从几个简单的使用场景开始:重命名属性,忽略属性,以及修改属性所使用的类型.注意:下面的例子仅仅显示了成员属性(field properties),注解同样也可以用在成员方法(getter ...
- scikit-learn主要模块和基本使用方法
从网上看到一篇总结的很不错的sklearn使用文档,备份勿忘. 引言 对于一些开始搞机器学习算法有害怕下手的小朋友,该如何快速入门,这让人挺挣扎的.在从事数据科学的人中,最常用的工具就是R和Pytho ...
- 一次完整的HTTP事务分析
在浏览器中输入一个地址,按下回车之后,到用户看到页面之前,发生了什么? https://www.processon.com/view/link/56c6679ce4b0f0c4285e69c0
- Android判断当前线程是否是主线程的方法
开发过程中有时候会在Thread类中执行某些操作,有些操作会由于Android版本的不同,尤其是低版本而Crash,因此必要的时候会查看某些容易引起crash的操作是否是在主线程,这里举三种方法: 方 ...
- phpStorm无法使用svn1.8的解决办法
1.安装SVN的Command Lines Tools. 2.在phpStorm的SVN属性中,将Use Command Line Client填入:C:\Program Files\Tortoise ...
- oracle中查询某张表都被哪些表参照了
起因: 系统测试的时候发现如果某条记录已经被引用了,这个时候删除这条记录会引起数据不一致,系统会报错.比如警员信息,在考勤记录表里会引用警员ID,如果考勤记录表中已经存在这个警员ID了,这时从警员表中 ...
- 仿iReader切换皮肤进度条
仿iReader切换皮肤进度条 标签(空格分隔): 自定义View [TOC] 本以为使用paint.setXfermode(new PorterDuffXfermode(Mode.XOR));可以轻 ...
- 游戏服务器ID生成器组件
游戏服务器程序中,经常需要生成全局的唯一ID号,这个功能很常用,本文将介绍一种通用ID生成组件.游戏服务器程序中使用此组件的场景有: 创建角色时,为其分配唯一ID 创建物品时,每个物品需要唯一ID 创 ...
- 一张Windows版本发展图——纪念XP服役13你年
88年的人,接触PC十几年.第一次真正开始学习PC是在小学四年级的电脑兴趣班上,那时候好多事情还历历在目.那些年,神秘的DOS,向里面输入一些自己都不懂得命令,出现的场景让一个少年内心砰砰直跳.一个& ...
- [原]编译Android源码过程中遇到的问题
编译Android源码的过程参考Android官网介绍: 1.下载Android源码的步骤:https://source.android.com/source/downloading.html 2.编 ...