asp.net Linq 实现分组查询
首先我们还是先建立一个person.cs类
public class person
{
public string name
{ get; set; }
public int age
{ get; set; }
public string sex
{ get; set; }
}
接下来我们往这个person类添加数据:
List plist1 = new List();
plist1.Add(new person { name = "cxx1", age = , sex = "男" });
plist1.Add(new person { name = "www.baidu.com", age = , sex = "男" });
plist1.Add(new person { name = "www.52mvc.com", age = , sex = "男" });
List plist2 = new List();
plist2.Add(new person { name = "cxx1", age = , sex = "男" });
plist2.Add(new person { name = "cxx2", age = , sex = "男" });
plist2.Add(new person { name = "cxx4", age = , sex = "男" });
plist2.Add(new person { name = "cxx5", age = , sex = "男" });
// asp.net
var query = from person p in plist1
join person per in plist2
on p.name equals per.name
select new
{
名称=p.name,
性别=p.sex,
年龄=p.age
};
gd2.DataSource = query;
gd2.DataBind();
返回的结果是:

备注:这个方法是要查找出 plist1 与 plist2 之中,name名称有相同记录的数据。
接下来我们来看看sql中的左连接left join 在linq中如何实现
还是先来创建两个cs 类。
///
/// 手机列表
///
public class MobileStore
{
public string mobId
{ set; get; }
public string mobName
{ set; get; }
}
/// 手机销售表
///
public class MobileSale
{
public string Sid
{ set; get; }
public string mobId
{ set; get; }
public string mobName
{ set; get; }
public string price
{ set; get; }
}
List listStore = new List();
listStore.Add(new MobileStore { mobId = "", mobName = "N86" });
listStore.Add(new MobileStore { mobId = "", mobName = "N82" });
listStore.Add(new MobileStore { mobId = "", mobName = "N81" });
listStore.Add(new MobileStore { mobId = "", mobName = "N95" });
listStore.Add(new MobileStore { mobId = "", mobName = "N85" });
listStore.Add(new MobileStore { mobId = "", mobName = "N97" });
List listSale = new List();
listSale.Add(new MobileSale { Sid="" ,mobId="",mobName="N86",price=""});
listSale.Add(new MobileSale { Sid="", mobId = "", mobName = "N82",price="" });
listSale.Add(new MobileSale { Sid = "", mobId = "", mobName = "N81", price = "" });
var query = from MobileStore m in listStore
join MobileSale sale in listSale
on m.mobId equals sale.mobId into joinm
from j in joinm.DefaultIfEmpty()
select new
{
ID = m.mobId,
名称 = m.mobName,
价格 = j == null ? "暂无数据" : j.price,
};
gd.DataSource = query;
gd.DataBind();
asp.net Linq 实现分组查询的更多相关文章
- linq中分组查询而且获取每个分组中的第一条记录,数据用于分页绑定
LINQ分组取出第一条数据 Person1: Id=1, Name="Test1" Person2: Id=1, Name="Test1" Person3: I ...
- LINQ to Entities 查询语法
转自: http://www.cnblogs.com/asingna/archive/2013/01/28/2879595.html 实体框架(Entity Framework )是 ADO.NET ...
- MVC项目实践,在三层架构下实现SportsStore-09,ASP.NET MVC调用ASP.NET Web API的查询服务
ASP.NET Web API和WCF都体现了REST软件架构风格.在REST中,把一切数据视为资源,所以也是一种面向资源的架构风格.所有的资源都可以通过URI来唯一标识,通过对资源的HTTP操作(G ...
- 浅谈sql 、linq、lambda 查询语句的区别
浅谈sql .linq.lambda 查询语句的区别 LINQ的书写格式如下: from 临时变量 in 集合对象或数据库对象 where 条件表达式 [order by条件] select 临时变量 ...
- LinQ to SQL 查询
LINQ to SQL 是将对象关系映射到.NET框架中的一种实现.它可以将关系数据库映射为.NET Framework中的一些类. 然后,开发人员就可以通过使用 LINQ to SQL对数据库中的数 ...
- C# - LINQ 语言集成查询
LINQ(Language Integrated Query) LINQ语言集成查询是一组用于C#语言的扩展.它允许编写C#代码对数据集进行查询,比如查询内存中的对象或查询远程数据库的表.利用linq ...
- C#编程(六十二)---------LINQ标准的查询操作符
LINQ标准的查询操作符 首先我们来看一下LINQ的操作符,可根据查询操作符的操作”类型”进行分类,如把它们分成投影,限制,排序,联接,分组,串联,聚合,集合,生成,转换,元素,相等,量词,分割等. ...
- CASE函数 sql server——分组查询(方法和思想) ref和out 一般处理程序结合反射技术统一执行客户端请求 遍历查询结果集,update数据 HBuilder设置APP状态栏
CASE函数 作用: 可以将查询结果集的某一列的字段值进行替换 它可以生成一个新列 相当于switch...case和 if..else 使用语法: case 表达式/字段 when 值 then ...
- MySQL时间分组查询
表TESTER 字段:id -- INT date -- TIMESTAMP 1.如何按年.月.日分组查询? select DATE_FORMAT(date,'%Y-%m-%d') time, ...
随机推荐
- jQuery 的属性操作方法
jQuery 属性操作方法 下面列出的这些方法获得或设置元素的 DOM 属性. 这些方法对于 XML 文档和 HTML 文档均是适用的,除了:html(). 方法 描述 addClass() 向匹配的 ...
- Mysql查找如何判断字段是否包含某个字符串
Mysql查找如何判断字段是否包含某个字符串 有这样一个需求,在Mysql数据库字符串字段(权限)中,用户有多个不同的邮箱,分别被‘,’分开,现在要取出某个邮箱的所有成员列表. 假设有个表: ...
- 【Android - 基础】之PopupWindow的使用
创建一个类继承自PopupWindow,编写自定义的PopupWindow类.示例代码如下: import android.app.Activity; import android.graphics. ...
- WebSocket与Tcp连接
最近做了一个项目,客户端为WebSocket页面,服务器端为Tcp控制台 .将代码贴出来,供需要的参考. 1.服务器端代码 其中服务器的Session使用了第三方插件,为TCP连接. 2.客户端代码如 ...
- Cocos2d 3.0继承自Sprite的类在addChild后出现故障
当继承自Sprite的类被addChild到其它的Node里后出现例如以下图问题,说明没有调用父类Sprite::init()的方法.由于父类Sprite里的_textureAtlas须要初始化为nu ...
- SQL Server与Oracle对比学习:表的管理和组织
http://blog.csdn.net/weiwenhp/article/details/8088979 我们知道数据库,顾名思义.最重要的东东就是管理数据,而数据在系统中主要是保存在表(table ...
- 3第一周课后练习·阅读计划(2)-使用指针来访问私有数据成员
/* * Copyright (c) 2015, 计算机科学学院,烟台大学 * All rights reserved. * 文件名:test.cpp * 作 靠:刘畅 * 完成日期:2015年 3 ...
- Linux和Windows互传文件命令(转)
sftp>lls 显示当前目录内容 sftp>lcd g:\ 进入本地g盘 sftp>put phpMyAdmin.zip 将本地g盘下的phpMyAdmin.zip上传到/home ...
- oracle4
分页查询 按雇员的id号升序取出 oracle的分页一共有三种方式 .根据rowid来分 ) ) order by cid desc; 执行时间0.03秒 .按分析函数来分 and rk> ...
- 基于Lucene的文件检索Demo
通过Lucene实现了简单的文件检索功能的Demo.这个Demo支持基于文件内容的检索,支持中文分词和高亮显示. 下面简单的介绍下核心的类 1)索引相关的类 1.FileIndexBuilder -- ...