Linq Group by获取数量和数据
主表:
public partial class Activity
{
[Key]
public int pkActivity { get; set; }
public int fkEmployee { get; set; }
public string ActivityName { get; set; }
public DateTime RegistrationStartDateTime { get; set; }
public DateTime RegistrationEndDateTime { get; set; }
public DateTime StartDateTime { get; set; }
public DateTime EndDateTime { get; set; }
public int MaxNumOfPeople { get; set; }
public decimal PricePerPeople { get; set; }
public string ActivityLocation { get; set; }
public string ActivityStatus { get; set; }
public string Description { get; set; }
public string ImgUrl { get; set; }
public DateTime CreateOn { get; set; }
public string CreateBy { get; set; }
public DateTime LastModifyOn { get; set; }
public string LastModifyBy { get; set; }
}
重表:
public partial class ActivityEmployee
{
[Key]
public int pkActivityEmployee { get; set; }
public int fkActivity { get; set; }
public int fkEmployee { get; set; }
public string Comments { get; set; }
public DateTime CreateOn { get; set; }
public string CreateBy { get; set; }
}
获取当前活动注册人数linq 写法,用DefaultIfEmpty 表示left join,通过group by new 进行分组,并通过groupedTable.Key.属性 提取数据:
/// <summary>
/// 获取我创建的活动列表。
/// </summary>
/// <param name="employeeKey"></param>
/// <returns></returns>
public IEnumerable<ActivityDTO> GetMyCreatedActivitiesList(int employeeKey)
{
var query = from activity in clientDbContext.Activity
join activityEmployee in clientDbContext.ActivityEmployee
on activity.pkActivity equals activityEmployee.fkActivity into temp
from t in temp.DefaultIfEmpty()
where activity.fkEmployee == employeeKey
group t by new
{
activity.pkActivity,
activity.fkEmployee,
activity.ActivityName,
activity.RegistrationStartDateTime,
activity.RegistrationEndDateTime,
activity.StartDateTime,
activity.EndDateTime,
activity.ImgUrl,
activity.ActivityStatus,
activity.ActivityLocation,
activity.Description,
activity.CreateOn,
activity.CreateBy,
activity.LastModifyBy,
activity.LastModifyOn
}
into groupActivity
select new ActivityDTO()
{
Id = groupActivity.Key.pkActivity,
CreatedEmployeKey = groupActivity.Key.fkEmployee,
ActivityName = groupActivity.Key.ActivityName,
RegistrationStartDateTime = groupActivity.Key.RegistrationStartDateTime,
RegistrationEndDateTime = groupActivity.Key.RegistrationEndDateTime,
StartDateTime = groupActivity.Key.StartDateTime,
EndDateTime = groupActivity.Key.EndDateTime,
ActivityImageUrl = groupActivity.Key.ImgUrl,
ActivityStatus = groupActivity.Key.ActivityStatus,
ActivityLocation = groupActivity.Key.ActivityLocation,
Description = groupActivity.Key.Description,
CreateOn = groupActivity.Key.CreateOn,
CreateBy = groupActivity.Key.CreateBy,
LastModifyBy = groupActivity.Key.LastModifyBy,
LastModifyOn = groupActivity.Key.LastModifyOn,
RegisteredCount = groupActivity.Count(g=>g.fkActivity!=null)//报名人数,left join存在null数据
}; return query;
}
Linq Group by获取数量和数据的更多相关文章
- 用LINQ获取XML节点数据
Insus.NET想对<从字符串中获取XML节点数据> http://www.cnblogs.com/insus/p/3299052.html 这篇改写为使用LINQ的方法实现.LINQ中 ...
- WindowsPhone 在 根据公历 获取月球日期数据
WindowsPhone 在 根据公历 获取月球日期数据 WindowsPhone 在 它们的定义 类,根据公历 获取月球日期数据 using System; using System.Collect ...
- 使用Socket通信实现Silverlight客户端实时数据的获取(模拟GPS数据,地图实时位置)
原文:使用Socket通信实现Silverlight客户端实时数据的获取(模拟GPS数据,地图实时位置) 在上一篇中说到了Silverlight下的Socket通信,在最后的时候说到本篇将会结合地图. ...
- 以多进程读取oss符合条件的数据为例,综合使用多进程间的通信、获取多进程的数据
import datetime import sys import oss2 from itertools import islice import pandas as pd import re im ...
- C#使用Linq to csv读取.csv文件数据
前言:今日遇到了一个需要读取CSV文件类型的EXCEL文档数据的问题,原本使用NPOI的解决方案直接读取文档数据,最后失败了,主要是文件的类型版本等信息不兼容导致.其他同事有使用linq to csv ...
- 用struts2标签如何从数据库获取数据并在查询页面显示。最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变量。
最近做一个小项目,需要用到struts2标签从数据库查询数据,并且用迭代器iterator标签在查询页面显示,可是一开始,怎么也获取不到数据,想了许久,最后发现,是自己少定义了一个变量,也就是var变 ...
- 读取TDrawGrid之获取博易数据
朋友叫我帮忙写个从博易读取数据的工具,可无奈数据所在控件并不是Windows标准控件,也就是说没办法通过发送系统消息来获取 相关数据,于是乎试了一下从内存直接读取,可最后并不能达到预期目的,原因是笔者 ...
- C#中,使用正式表达式匹配获取所需数据
.NET中,使用正式表达式匹配获取所需数据 需求:获取一串字符串中,正则匹配出需要的数据. 例如以下字符串: string temp ="ErrorCode:-1,Message:{&quo ...
- 速战速决 (6) - PHP: 获取 http 请求数据, 获取 get 数据 和 post 数据, json 字符串与对象之间的相互转换
[源码下载] 速战速决 (6) - PHP: 获取 http 请求数据, 获取 get 数据 和 post 数据, json 字符串与对象之间的相互转换 作者:webabcd 介绍速战速决 之 PHP ...
随机推荐
- Java自学-Lambda 概念
Java Lambda 表达式概念 假设一个情景: 找出满足条件的Hero 从使用普通方法,匿名类,以及Lambda这几种方式,逐渐的引入Lambda的概念 步骤 1 : 普通方法 使用一个普通方法, ...
- vue 项目初始化
初始化 vue init webpack-simple myproject 安裝 npm install 运行 npm run dev 访问地址 http://localhost:8080/ 安装we ...
- 测度论--长度是怎样炼成的[zz]
http://www.58pic.com/newpic/27882296.html http://www.58pic.com/newpic/27893137.html http://699pic.co ...
- D0 设计模式
单一职责 一个类只负责一个功能领域中的相应职责.,就一个类而言,应该只有一个引起它变化的原因. 单一职责原则告诉我们: 一个类不能太"累"! 在软件系统中, 一个类( 大到模块, ...
- 2019牛客多校第五场C generator 2 hash,bsgs模板
generator 2 题意 给出\(x_0,a,b,p\),有方程\(x_i\equiv (a*x_{i-1}+b)(\% p)\),求最小的i,使得\(x_i=v\),不存在输出-1 分析 经过公 ...
- Centos6.5安装Nmap、tcpdump、mysql、tomcat、靶场WAVSEP
nmap安装 输入命令如下: yum install nmap 安装完成后,输入nmap -h看是否安装成功. 安装tcpdump 安装tcpdump必须的库: yum install flex yu ...
- Itext相关知识
最近需求用到office和pdf相关知识,office使用poi操作的,pdf则使用Itext操作 Itext官网: http://itextpdf.com/ Itext7相关使用示例:https:/ ...
- bzoj 3669: [Noi2014]魔法森林 (LCT & kruskal)
这道题呢, 首先按照关键字a排序,然后不断地加边,用lct维护这个过程 具体实现: 先按照关键字a排序,枚举每一条边,判断两点是否已经联通(kruskal 部分)如果联通,就在两点路径间寻找最大的b, ...
- Strategic game树形DP解法(Poj1463,Uva1292)
已经写过本题用二分图的做法,见这儿. 本题的图是一棵树,求最小点覆盖也可以用树形DP的做法. 定义状态f[0/1][u]表示以u为根的子树,u选取/不选最少需要选取多少点来覆盖. 显然 f[0][u] ...
- linux下删除空行的几种方法
在查看linux下的配置文件时,为了便于一目了然的查看,经常会删除空行和#头的行.而linux在删除空行的方法很多,grep.sed.awk.tr等工具都能实现.现总结如下: 1.grep grep ...