我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Linq中怎么自定义组合查询

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Linq中怎么自定义组合查询

本篇文章为大家展示了Linq中怎么自定义组合查询,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

这个表单将Linq自定义组合条件提交后台,我先将它封装成条件对象的数组。

///  /// 条件  ///  public class Condition  {      ///      /// 字段      ///      public string Field { get; set; }      ///      /// 表达式      ///      public string Operator { get; set; }      ///      /// 值      ///      public string Value { get; set; }      ///      /// 关系      ///      public string Relation { get; set; }       ///      ///       ///      ///      ///      ///      ///      ///      public static Condition[] BuildConditions(string[] fileds,string[] operators,string[] values,string[] relations)      {          if (fileds == null || operators == null || values == null || relations == null)          {              return null;          }          Condition[] conditions = new Condition[fileds.Length];          try         {              for (int i = 0; i < conditions.Length; i++)              {                  conditions[i] = new Condition()                  {                      Field = fileds[i],                      Operator = operators[i],                      Value = values[i],                      Relation = relations[i]                  };              }          }          catch         {              return null;          }          return conditions;      }  }

实际上,编译器是把Linq自定义表达式编译成expression tree的形式,我只需要将条件对象数组转换为expression tree就可以了。

我先将一个条件转化为一个简单的expression。

///  ///   ///  ///  ///  ///  private static Expression ConditonToExpression(Condition condition,Expression parameter)  {      Expression expr = null;      Type type = typeof(EDM_Resource);       PropertyInfo pi = type.GetProperty(condition.Field);      Expression left = Expression.Property(parameter, pi);       object value = Convert.ChangeType(condition.Value, pi.PropertyType);      Expression right = Expression.Constant(value);      switch (condition.Operator)      {          case "=":              expr = Expression.Equal(left, right);              break;          case "<":              expr = Expression.LessThan(left, right);              break;          case "<=":              expr = Expression.LessThanOrEqual(left, right);              break;          case ">":              expr = Expression.GreaterThan(left, right);              break;          case ">=":              expr = Expression.GreaterThanOrEqual(left, right);              break;      }      return expr;  }

然后组合,变成一个lamda表达式,追加到where上。

///  ///   ///  ///  ///  ///  ///  ///  ///  public IList FindByGroup(EDM_ResGroup resGroup, Condition[] conditions, int first, int limit, out int count)  {      using (ShengjingEDM2Entities context = new ShengjingEDM2Entities())      {          IQueryable result = DoFindByGroup(resGroup, context);          ParameterExpression parameter = Expression.Parameter(typeof(EDM_Resource), "r");          Expression body = null;           if (conditions != null && conditions.Length > 0)          {              body = ConditonToExpression(conditions[0], parameter);              for (int i = 1; i < conditions.Length; i++)              {                  Expression right = ConditonToExpression(conditions[i],parameter);                  body = conditions[i - 1].Relation.ToUpper().Equals("AND") ?                      Expression.And(body, right) :                      Expression.Or(body, right);              }          }           if (body != null)          {              Expression<FUNC<EDM_RESOURCE, < SPAN>bool>> expr = Expression.Lambda<FUNC<EDM_RESOURCE, < SPAN>bool>>(body, parameter);              result = result.Where(expr);          }          result = result.OrderByDescending<EDM_RESOURCE, < SPAN>int>(r => r.ResourceID);          count = result.Count();          return result              .Skip(first)              .Take(limit)              .ToList();      }  }

原来Linq自定义这么强大,这么爽,比拼where条件的方法优雅多了,开发效率也是提高不少,而且我发现性能也不错,100万级的数据通过索引和分页查询还算可以。

上述内容就是Linq中怎么自定义组合查询,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Linq中怎么自定义组合查询

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Linq中怎么自定义组合查询

本篇文章为大家展示了Linq中怎么自定义组合查询,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。这个表单将Linq自定义组合条件提交后台,我先将它封装成条件对象的数组。/// /// 条件 ///
2023-06-17

LINQ组合查询怎么简化编程

本篇内容介绍了“LINQ组合查询怎么简化编程”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 初始化数组通常,我们需要把数组的值初始化为相
2023-06-17

LINQ中怎么自定义业务

LINQ中怎么自定义业务,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。LINQ TO SQL很好很强大,它几乎包含了我们能够想到的所有与数据库有关的操作,甚至也
2023-06-17

Linq组合查询怎么集成数据库语言查询

本篇内容主要讲解“Linq组合查询怎么集成数据库语言查询”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Linq组合查询怎么集成数据库语言查询”吧!通常来讲,Linq组合查询提供了一条很常规的途径
2023-06-17

Linq中怎么查询二维数组

这篇文章给大家介绍Linq中怎么查询二维数组,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。Linq查询二维数组以下代码为在一个4*4的二维int数组中将大于5的元素查出:static void Main( str
2023-06-17

android怎么自定义组合控件

要自定义一个组合控件,你可以按照以下步骤进行:1. 创建一个新的类,继承自现有的Android控件类,例如LinearLayout或RelativeLayout。2. 在构造函数中,通过LayoutInflater将组合控件的布局文件加载进
2023-08-09

LINQ中怎么利用 from子句实现复合查询

LINQ中怎么利用 from子句实现复合查询,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1.用LINQ from子句进行复核查询using System; using Sy
2023-06-17

JPA怎么使用findBy方法自定义查询

这篇文章给大家分享的是有关JPA怎么使用findBy方法自定义查询的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。JPA使用findBy方法自定义查询最近在项目中使用spring boot+jpa的方式来访问数据库
2023-06-21

怎么使用JPA自定义SQL查询结果

本篇内容介绍了“怎么使用JPA自定义SQL查询结果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!JPA自定义SQL查询结果很多时候都会遇到自
2023-06-25

MySQL子查询怎么定义

本篇内容主要讲解“MySQL子查询怎么定义”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“MySQL子查询怎么定义”吧!定义:select语句中嵌套select语句,被嵌套的select语句是子查
2022-11-30

Linq中怎么实现连接查询

今天就跟大家聊聊有关Linq中怎么实现连接查询,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。Linq连接查询之前先建立两个查询:using (DataClassesDataConte
2023-06-17

linq中怎么实现多表查询

这篇文章给大家介绍linq中怎么实现多表查询,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。1:1关系的多表操作表结构如上首先是测试取全记录的情况(也就是取所有字段)linq多表查询之直接写表达式var user = c
2023-06-17

LINQ中怎么实现动态查询

今天就跟大家聊聊有关LINQ中怎么实现动态查询,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。LINQ动态查询实现实例:case L: case l: NextChar(); i
2023-06-17

Linq中怎么分析查询结果

这篇文章给大家介绍Linq中怎么分析查询结果,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。使用Linq查询结果:如果查询结果是强类型的,如string[],List等,就可以不用var类型,而是使用合适的 IEnume
2023-06-17

LINQ中怎么实现嵌套查询

这篇文章将为大家详细讲解有关LINQ中怎么实现嵌套查询,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。LINQ嵌套查询应用实例:如果我们需要取出市场部的所有员工,在以往的O/R Mapping
2023-06-17

Flex中怎么自定义itemeditor组件

在 Flex 中,可以通过自定义 ItemEditor 组件来实现自定义的编辑器。以下是一个简单的示例:1. 首先,创建一个自定义的 ItemEditor 组件。可以继承自 Flex 自带的 ItemEditor 类,或者实现 IItemE
2023-09-27

Linq中怎么实现多条件查询

这篇文章将为大家详细讲解有关Linq中怎么实现多条件查询,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。Linq多条件查询(高级搜索),假如一共可以输入5个条件,但是用户根据需要可能只输2个或
2023-06-17

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录