• 安装
  • 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 动态查询的更多相关文章

  1. System.Linq.Dynamic的使用

    项目中经常用到组合条件查询,根据用户配置的查询条件进行搜索,拼接SQL容易造成SQL注入,普通的LINQ可以用表达式树来完成,但也比较麻烦.有个System.Linq.Dynamic用起来比较方便. ...

  2. System.Linq.Dynamic 和Nhibernate

    var session = NHibernateSessionManager.Instance.GetSession(); "); var staffList = session.Query ...

  3. System.Linq.Dynamic

    http://dynamiclinq.codeplex.com/ 10万回 用动态表达式 0.19s ,普通Lamba 0.02s,效率还可以 /* User: Peter Date: 2016/4/ ...

  4. EF Core中关于System.Linq.Dynamic.Core的使用(转载)

    项目中经常用到组合条件查询,根据用户配置的查询条件进行搜索,拼接SQL容易造成SQL注入,普通的LINQ可以用表达式树来完成,但也比较麻烦.有个System.Linq.Dynamic.Core用起来比 ...

  5. 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 ...

  6. System.Linq.Dynamic字符串转委托

    以前一直想着有没有一个方法能够把字符串直接转化成函数的,刚好有需求就找了下,还真有. 微软地址:https://docs.microsoft.com/en-us/previous-versions/b ...

  7. 【转】借助System.Linq.Dynamic, IQueryable根据排序字符串排序

    在使用Entity Framework时,若有多个排序,需要OrderBy (OrderByDescending)再ThenBy (ThenByDescending) 假设需要根据Name升序排序,再 ...

  8. 借助System.Linq.Dynamic, IQueryable根据排序字符串排序

    在使用Entity Framework时,若有多个排序,需要OrderBy (OrderByDescending)再ThenBy (ThenByDescending) 假设需要根据Name升序排序,再 ...

  9. EF 6.x、EF Core实现dynamic动态查询和EF Core实现多个上下文实例池你了解多少?

    前言 很长一段时间没有写博客了,今天补上一篇吧,偶尔发现不太愿意写博客了,太耗费时间,不过还是在坚持当中,毕竟或许写出来的东西能帮到一些童鞋吧,接下来我们直奔主题.无论是在在EF 6.x还是EF Co ...

随机推荐

  1. PHP 清除HTML代码、空格、回车换行符的函数

    function DeleteHtml($str) { $str = trim($str); $str = strip_tags($str,""); $str = ereg_rep ...

  2. 可以输入也可以下拉选择的select

    网址:http://www.helloweba.com/view-blog-348.html 示例:http://www.helloweba.com/demo/2016/editable-select ...

  3. Hadoop2的FN安装(federated namespace)

    尝试了简单的安装hadoop2后,我们再来尝试一下hdfs的一项新功能:FN.这项技术可以解决namenode容量不足的问题.它采用多个namenode来共享datanode的方式,每个namenod ...

  4. 一起talk C栗子吧(第一百二十七回:C语言实例--查看main函数的參数)

    各位看官们,大家好,上一回中咱们说的是static关键字的样例,这一回咱们说的样例是:查看main函数的參数.闲话休提,言归正转.让我们一起talk C栗子吧! 看官们.我们在第五十七回中介绍过mai ...

  5. 在UI线程之外,多线程处理Bitmaps

    多线程处理Bitmaps     上一篇,我们讨论了:Android有效的处理Bitmap,降低内存 ,可是最好不要运行在主线程(UI线程),假设图片是本地的或者网络的又或者是其它地方的. 图片载入的 ...

  6. cascade(级联)和inverse关系详解

    序言 写这篇文章之前,自己也查了很多的资料来搞清楚这两者的关系和各自所做的事情,但是百度一搜,大多数博文感觉说的云里雾里,可能博主自己清楚是怎么一回事,但是给一个不懂的人或者一知半解的人看的话,别人也 ...

  7. vue父子组件传值

    1.父组件向子组件传值 例如app.vue是父组件,v-header.vue是子组件,实现app向v-header传值父组件需要自定义自己的title值, 子组件v-header内容 <temp ...

  8. AutoArchive settings explained

    AutoArchive settings explained Applies To: Outlook 2010 More... Less AutoArchive helps manage the sp ...

  9. Python mock 的使用

    使用 mock 对象替换系统的一部分并且能获取它们的使用情况. 具体的说,你可以获取方法/属性的使用情况以及它们的调用参数.也可以指定返回值和设置属性. 思路是将对象设置为 mock 对象,然后根据需 ...

  10. druid

    实时分析型数据库 Druid | Interactive Analytics at Scale http://druid.io/ Druid is primarily used to store, q ...