前言

接口获取参数后,创建返回值模型的条件表达式作为参数,传入使用依赖注入实例化后的业务层。

业务层创建返回值模型的IQUERY后,再使用参数条件表达式。最后进行延迟查询。

代码实现

参数模型DemoParaModel

    public class DemoParaModel
{
/// <summary>
/// 必填参数
/// </summary>
[Required]
public string Age { get; set; } public string Name { get; set; } }

ORM实体Demo_Age

    [Table("DEMO_AGE")]
public class Demo_Age
{ [Column("ID", IsPrimaryKey = true)]
public string ID { get; set; } [Column("AGE")]
public string Age { get; set; } }

ORM实体Demo_Name

    [Table("DEMO_NAME")]
public class Demo_Name
{
[Column("ID", IsPrimaryKey = true)]
public string ID { get; set; } [Column("Name")]
public string Name { get; set; }
}

返回值模型

    public class View_DemoPerson
{
public string ID { get; set; } public string Name { get; set; } public string Age { get; set; } }

控制器接口

构造表达式时的AND方法的实现:Linq.Expressions扩展

    public class DemoController : BaseController
{ #region 服务 private IDemoService _demoService;
public DemoController(IDemoService demoService)
{
_demoService = demoService;
} #endregion public ActionResult Login(DemoParaModel paraModel)
{ //创建表达式
Expression<Func<View_DemoPerson, bool>> lambdaExpression = t => true; //构造表达式
if (!string.IsNullOrWhiteSpace(paraModel.Age))
{
lambdaExpression = lambdaExpression.And(t => t.Age == paraModel.Age);
}
if (!string.IsNullOrWhiteSpace(paraModel.Name))
{
lambdaExpression = lambdaExpression.And(t => t.Name == paraModel.Name);
} //获取视图模型数据
List<View_DemoPerson> list = _demoService.DemoDoSomeThing(lambdaExpression); //返回数据
return JsonResult(list); }
}

业务层接口

    public interface IDemoService
{ List<View_DemoPerson> DemoDoSomeThing(Expression<Func<View_DemoPerson, bool>> lambda = null); }

业务层接口实例

   public class DemoService : ServiceBase, IDemoService
{ public List<View_DemoPerson> DemoDoSomeThing(Expression<Func<View_DemoPerson, bool>> lambda = null)
{
List<View_DemoPerson> list = new List<View_DemoPerson>();
using (DbContext)
{ //先获取业务所有涉及表的数据库实体的IQuery
IQuery<Demo_Name> query_DemoName = DbContext.Query<Demo_Name>();
IQuery<Demo_Age> query_DemoAge = DbContext.Query<Demo_Age>(); //将数据库实体的IQuery关联查询,创建出返回模型的IQuery
IQuery<View_DemoPerson> query_View_DemoPerson =
query_DemoName.LeftJoin(query_DemoAge, (x, y) => x.ID == y.ID)
.Select(
(x, y) => new View_DemoPerson
{
ID = x.ID,
Name = x.Name,
Age = y.Age
}); //对返回模型的IQuery使用传进来的条件表达式参数
query_View_DemoPerson = query_View_DemoPerson.Where(lambda); //延迟查询
list = query_View_DemoPerson.ToList(); } return list; } }

ORM动态表达式树查询的更多相关文章

  1. 利用 DynamicLinq 实现简单的动态表达式构建查询

    平时使用 LINQ 进行一些简单的条件拼接查询一般都会这样操作: public class SearchInputDto { public string ConditionA { get; set; ...

  2. 超简单的集成表达式树查询组件,Sy.ExpressionBuilder 使用说明

    Sy.ExpressionBuilder是一套依赖于表达式树上的集成的查询组件.设计的初衷没别的,就为了少写代码,让查询业务可以变得更加模式化.目前可以从nuget 获取到该组件. 来到查询,查询实体 ...

  3. C# 表达式树学习笔记

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  4. 【C#表达式树 一】Expressions 命名空间 38个类 2个接口 3个枚举

    注解 抽象类 Expression 提供用于为表达式树建模的类层次结构的根. 此命名空间中派生自的类 Expression (例如 MemberExpression 和 ParameterExpres ...

  5. EntityFramework动态多条件查询与Lambda表达式树

              在常规的信息系统中, 我们有需要动态多条件查询的情况, 例如UI上有多个选择项可供用户选择多条件查询数据. 那么在.net平台Entity Framework下, 我们用Lambd ...

  6. EF4.0、4.3创建表达式树状动态查询总结

    ---------------------------------------------快速适用 效果: where name like '%王%' and Age>=35 or Age< ...

  7. 表达式树在LINQ动态查询

    动态构建表达式树,最佳实践版,很实用! public class FilterCollection : Collection<IList<Filter>> { public F ...

  8. c#——表达式树在LINQ动态查询

    一般如果逻辑比较简单,只是存在有的情况多一个查询条件,有的情况不需要添加该查询条件 简单方式这样操作就可以了 public IQueryable<FileImport> DynamicCh ...

  9. Asp.net Core C#进行筛选、过滤、使用PredicateBuilder进行动态拼接lamdba表达式树并用作条件精准查询,模糊查询

    在asp.net core.asp.net 中做where条件过滤筛选的时候写的长而繁琐不利于维护,用PredicateBuilder进行筛选.过滤.LInq配合Ef.core进行动态拼接lamdba ...

随机推荐

  1. 点击劫持(Iframe clickJack)练习

    实验内容: 寻找一个合适的网站放入到iframe标签中.实验中测试了包括知网首页及登录界面.淘宝首页及登录界面,百度首页,微信下载界面.发现淘宝登录界面无法放入,会直接跳转到淘宝真实的登录界面,其他的 ...

  2. 第六章 Sleuth--链路追踪

    修整了2天,我们继续接着上篇 第五章 Gateway–服务网关 继续来讲SpringCloud Alibaba全家桶中的 Sleuth 链路追踪 组件 喜欢记得点关注哦 6.1 链路追踪介绍 在大型系 ...

  3. Python 学习笔记(上)

    Python 学习笔记(上) 这份笔记是我在系统地学习python时记录的,它不能算是一份完整的参考,但里面大都是我觉得比较重要的地方. 目录 Python 学习笔记(上) 基础知识 基本输入输出 模 ...

  4. Centos7__Scrapy + Scrapy_redis 用Docker 实现分布式爬虫

    原理:其实就是用到redis的优点及特性,好处自己查--- 1,scrapy 分布式爬虫配置: settings.py BOT_NAME = 'first' SPIDER_MODULES = ['fi ...

  5. C#中无法找到microsoft.web文件

    原因 上午更新了vs2015后,找不到该文件. 解决方法 1.工具->Nuget包管理器->程序包管理器控制台-> 输入 Install-Package Microsoft.Web. ...

  6. struts文件上传拦截器分析

    struts有默认的文件拦截器,一般配置maximumSize就可以了. 知道原理,我们可以写一个类继承它,实现自己的配置上传文件大小的方式.   然后细究页面上传文件的时候,发现了一些问题. act ...

  7. 利用MD5进行加密

    package com.cn.peitest; import java.io.UnsupportedEncodingException; import java.security.MessageDig ...

  8. Linux嵌入式学习-交叉编译openssl

    利用arm-none-linux-gnueabi-gcc交叉编译openssl,生成静态库文件libcrypto.a ,libssl.a 1.从openssl官网下载openssl最新版本,我下载的是 ...

  9. docker 安装 运行 卸载

    一.卸载docker 安装时使用什么工具安装的docker就用什么工具卸载docker: 1.yum卸载docker 查看已安装的docker yum list installed | grep do ...

  10. JS 获取(期号、当前日期、本周第一天、最后一天及当前月第一、最后天函数)    

    JS 获取(期号.当前日期.本周第一天.最后一天及当前月第一.最后天函数 /** 2 * 获取当前月期号 3 * 返回格式: YYYY-mm 4 * / 5 function getCurrentMo ...