System.Linq.Dynamic 动态查询
- 安装
- VS->工具栏->NuGet程序管理器,System.Linq.Dynamic
- 注意:
使用动态查询必须先调用AsQueryable()方法,因为动态扩展仅适用于实现IQueryable的集合。然后迭代结果与常规Linq一样。
- 动态查询
using System.Linq.Dynamic
/// 得到明细过滤条件
/// </summary>
/// <returns></returns>
private string GetFilterWhere(out List<object> paramList)
{
StringBuilder strWhere = new StringBuilder();
object items;
paramList = new List<object>();
strWhere.AppendFormat("ProductionDate >=@{0}", paramList.Count);
paramList.Add(Convert.ToDateTime(startDetailDateEdit.EditValue).Date); strWhere.AppendFormat(" && ProductionDate <=@{0}", paramList.Count);
paramList.Add(Convert.ToDateTime(endDetailDateEdit.EditValue).Date); items = factoryDetailCheckedComboBoxEdit.Properties.GetCheckedItems();
if (items != null && items.ToString() != string.Empty)
{//数组参数,数组中是否包含实例相等的FactoryID值,“outerIt 代表实例”
strWhere.AppendFormat(" && @{0}.Contains(outerIt.FactoryID)", paramList.Count);
paramList.Add(UIHelper.ToArray(items.ToString()));
} if (cbCustomer.HasValue())
{
strWhere.AppendFormat(" && CustomerID=@{0}", paramList.Count);
paramList.Add(Convert.ToInt32(cbCustomer.SelectedValue));
} if (txtMachineCode.Text.Trim() != string.Empty)
{
strWhere.AppendFormat(" && MachineCode.Contains(@{0})", paramList.Count);
paramList.Add(txtMachineCode.Text.Trim());
} return strWhere.ToString();
} //查询
List<object> paramList;
string strWhere = GetFilterWhere(out paramList); //根据条件查询
var query = sourceList.AsQueryable<FacilityEfficiencyReportInfo>().Where(strWhere, paramList.ToArray());
var resultList = (from dynamic g in query select g).ToList();- 动态分组
/// <summary>
/// 得到分组的列名字符串
/// </summary>
/// <returns></returns>
private string GetGroupNames()
{
StringBuilder groupName = new StringBuilder();
if (m_FirstGroupFieldName != null)
{
groupName.Append(m_FirstGroupFieldName.Key);
}
if (m_SecondGroupFieldName != null)
{
if(groupName.Length>)
{
groupName.AppendFormat(",{0}", m_SecondGroupFieldName.Key);
}
else
{
groupName.Append(m_SecondGroupFieldName.Key);
}
}
if (m_ThirdGroupFieldName != null)
{
if(groupName.Length>)
{
groupName.AppendFormat(",{0}", m_ThirdGroupFieldName.Key);
}
else
{
groupName.Append(m_ThirdGroupFieldName.Key);
}
}
return groupName.ToString();
}object value;
string groupNames = GetGroupNames();
List<FacilityEfficiencyReportInfo> actualGroupList = new List<FacilityEfficiencyReportInfo>();//实际组列表,不区分日期
if (string.IsNullOrEmpty(groupNames))
{
actualGroupList = groupList.GroupBy(m => m.ID).Select(g => new FacilityEfficiencyReportInfo { FinishedAmount = g.Sum(m => m.FinishedAmount), Workers = g.Sum(m => m.Workers), Duration = g.Sum(m => m.Duration), Sam = g.Average(m => m.Sam),List=g.ToList() }).ToList();
}
else
{
var query = groupList.AsQueryable()
.GroupBy(string.Format("new ({0})", groupNames), "it")
.Select("new(it.Key as Key, it as GroupList)");
var tempGroupList = (from dynamic g in query select g).ToList();
foreach (var g in tempGroupList)
{//每一组合并成一个FacilityEfficiencyReportInfo实例,明细放入model.List列表
FacilityEfficiencyReportInfo newModel = null;
object test = g.Key;
foreach (FacilityEfficiencyReportInfo m in g.GroupList)
{
if (newModel == null)
{
newModel = m.Clone();
newModel.InitDate();
newModel.List = new List<FacilityEfficiencyReportInfo>();
}
newModel.List.AddRange(m.List);
}
actualGroupList.Add(newModel);
}
}query = Contact.GetContactsList().AsQueryable().Where("@0.Contains(outerIt.Country)", newList<String>() { "Austria", "Poland" });其中“outerIt”代表整理上下文:“联系人”列表。为此,我们应该定义一个“outerIt”关键字
query = Contact.GetContactsList().AsQueryable().Where("@0.Contains(outerIt.Country) && it.BirthDate.Year > @1", new List<string>() { "Austria", "Poland" }, );
System.Linq.Dynamic 动态查询的更多相关文章
- System.Linq.Dynamic的使用
项目中经常用到组合条件查询,根据用户配置的查询条件进行搜索,拼接SQL容易造成SQL注入,普通的LINQ可以用表达式树来完成,但也比较麻烦.有个System.Linq.Dynamic用起来比较方便. ...
- System.Linq.Dynamic 和Nhibernate
var session = NHibernateSessionManager.Instance.GetSession(); "); var staffList = session.Query ...
- System.Linq.Dynamic
http://dynamiclinq.codeplex.com/ 10万回 用动态表达式 0.19s ,普通Lamba 0.02s,效率还可以 /* User: Peter Date: 2016/4/ ...
- EF Core中关于System.Linq.Dynamic.Core的使用(转载)
项目中经常用到组合条件查询,根据用户配置的查询条件进行搜索,拼接SQL容易造成SQL注入,普通的LINQ可以用表达式树来完成,但也比较麻烦.有个System.Linq.Dynamic.Core用起来比 ...
- Cookies 初识 Dotnetspider EF 6.x、EF Core实现dynamic动态查询和EF Core注入多个上下文实例池你知道有什么问题? EntityFramework Core 运行dotnet ef命令迁移背后本质是什么?(EF Core迁移原理)
Cookies 1.创建HttpCookies Cookie=new HttpCookies("CookieName");2.添加内容Cookie.Values.Add(&qu ...
- System.Linq.Dynamic字符串转委托
以前一直想着有没有一个方法能够把字符串直接转化成函数的,刚好有需求就找了下,还真有. 微软地址:https://docs.microsoft.com/en-us/previous-versions/b ...
- 【转】借助System.Linq.Dynamic, IQueryable根据排序字符串排序
在使用Entity Framework时,若有多个排序,需要OrderBy (OrderByDescending)再ThenBy (ThenByDescending) 假设需要根据Name升序排序,再 ...
- 借助System.Linq.Dynamic, IQueryable根据排序字符串排序
在使用Entity Framework时,若有多个排序,需要OrderBy (OrderByDescending)再ThenBy (ThenByDescending) 假设需要根据Name升序排序,再 ...
- EF 6.x、EF Core实现dynamic动态查询和EF Core实现多个上下文实例池你了解多少?
前言 很长一段时间没有写博客了,今天补上一篇吧,偶尔发现不太愿意写博客了,太耗费时间,不过还是在坚持当中,毕竟或许写出来的东西能帮到一些童鞋吧,接下来我们直奔主题.无论是在在EF 6.x还是EF Co ...
随机推荐
- MemoryStream类读写内存
和FileStream一样,MemoryStream和BufferedStream都派生自基类Stream,因此它们有很多共同的属性和方法,但是每一个类都有自己独特的用法.这两个类都是实现对内存进行数 ...
- java算法-数学之美二
上一章已经说过利用数学思想来解决程序算法问题,实际上就是找规律.这在我们上学时经常遇到,比如给出一段数字,求某一个位置该填写什么数,只要找到规律那就迎刃而解.好了,废话不多说,再来看看案例分析. ...
- Java中static的使用
static 使用之静态变量: 大家都知道,我们可以基于一个类创建多个该类的对象,每个对象都拥有自己的成员,互相独立.然而在某些时候,我们更希望该类所有的对象共享同一个成员.此时就是 static 大 ...
- IOS-应用之间调用
本文转载至 http://blog.csdn.net/likendsl/article/details/7553605 原文作者的博客值得关注. ios应用之间的调用步骤: 一.调用自己开发的应用 1 ...
- android应用安全——代码安全(android代码混淆)
android2.3的SDK开始在eclipse中支持代码混淆功能(理论上java都支持混淆,但关键在于如何编写proguard的混淆脚本,2.3的SDK使用简单的配置就可以实现混淆).使用SDK2. ...
- GitHub上整理的一些工具【转】
技术站点 Hacker News:非常棒的针对编程的链接聚合网站 Programming reddit:同上 MSDN:微软相关的官方技术集中地,主要是文档类 infoq:企业级应用,关注软件开发领域 ...
- APP上传应用商店加固后打包
在cmd进入jdk的bin目录,把keystore文件和apk安装包放到bin目录下,然后执行以下命令,需要管理员权限: jarsgner -verbose -sigalg SHA1withRSA - ...
- Openstack虚拟机创建流程
续上一篇Openstack安装配置 一,keystone交互认证阶段 1,发送用户名和密码给keystone认证获取token 2,带着token访问nova-api 3,nova-api使用toke ...
- Powershell Get-FileHash
File Hash (Get-FileHash C:\fso\myfile.txt).hash Get-FileHash C:\Users\Andris\Downloads\Contoso8_1_EN ...
- Android REST webservice 类
App与后台交互,后台使用的是Jersey RESTful 服务.在APP端使用Android 内部集成的HttpClient接口,无需引入第三方jar包, import org.apache.htt ...