首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Asp.Net Core 扩展 Linq,简化自定义

前言 -为什么需要扩展 Linq 方法 Linq 在 .net 中使用是比较多的,而微软开发的 linq 相关函数无法满足实际项目开发中的需求,我们需要自己来扩展一些方法。...c# 扩展方法 在 Asp.Net Core 开发中或者其他的后端开发中都会有一个需求(尤其对于中台或者后台管理),那就是展示数据列表;当然不是普普通通的数据列表展示,而是需要进行排序、分页、查询关键字来获取列表...但是天无绝人之路,在 c#中拥有扩展方法、表达式目录树和反射,可以将上面的方式进行优化。...扩展方法 对于 Linq 扩展方法来说,需要使用到表达式目录树和反射等高级操作,本人目前对于此处理解不是太深,就越过这里了,直接说如何实现即可 public static class LinqExtension...T>, IQueryableT>>(query, resultQuery); } } 这样通过 linq 就可以直接调用 UseCoditionFind 然后获取返回的 query,然后再

1.7K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    .NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)

    LINQ支撑原理进行了大片理论的介绍,不知道效果如何; 在结束上一篇文章的时候,看到一个前辈评论说建议我多写写LINQ使用方面的,而不是讲这些理论。...如果我们使用扩展方法那么只能是扩展IEnumerableT>对象,这没有问题。我们可以很方便的在LINQ的表达式中调用我们自己的扩展方法,让自己的方法跟着一起链式查询。...那么在IQueryableT>中是通过执行Provider程序来获取数据,减少在一开始就获取数据的性能代价。...扩展方法的源代码,它扩展IQueryable对象,在方法内部都是在使用source对象来操作,source是扩展对象的直接引用。...这是问题的重点,对扩展方法、链式编程不熟悉的朋友很难将source能串联到之前方法所返回的IQueryableT>对象上。

    1.5K11

    C# 反射高级用法

    使用反射可以让我们在运行时动态地获取对象的类型信息并进行相应的操作,比如创建对象、调用方法、获取属性等。...举个简单的例子,我们在写代码时,为了能够调用某个对象的方法,我们通常需要先创建这个对象的实例,然后才能调用其方法。而使用反射机制,我们可以在运行时动态地创建对象并直接调用其方法,而不必提前定义它们。...接着,我们利用 PropertyInfo 对象获取、设置对象的属性值,最后打印属性值。以上就是用反射机制在 C# 中创建对象的过程。 3、反射调用方法 使用反射可以在运行时动态地调用对象的方法。...我们可以使用MethodInfo类来获取方法信息,然后调用MethodInfo.Invoke方法来调用这个方法,如下所示。...方法获取了TestMethod方法信息,然后使用MakeGenericMethod方法构造了泛型方法,并将其转化为MethodInfo类进行输出。

    28140

    由浅入深表达式树(二)遍历表达式树

    而第三种我们是利用了goto 语句,如果我们在表达式中想跳出循环,或者提前退出方法它就派上用场了。这们上一篇中也有讲到Expression.Return的用法。...,所以我们可以传递任意类型的表达式。...实际上Provider也就是接收了这个表达式树,然后进行遍历解释的,那么我们可以不要Provider直接进行翻译吗? I SAY YES! WHY CAN’T?...这就要看我们的表达式类型了,在我们的Where扩展方法中,我们传入的表达式树是由Expression.Call方法构造的,而它返回的是MethodCallExpression所以我们第一步是覆盖VisitMethodCall...在具体访问方法中,解释表达式,翻译成SQL语句。   实际上我们并没有干什么很复杂的事情,只要了解具体的表达式类型和具体表访问方法就可以了。

    1.1K50

    .NET中数据访问方式(一):LINQ

    扩展方法(又称为标准查询) System.Linq.Enumerable类和System.Linq.Queryable类,分别针对IEnumerableT>和IQueryableT>接口进行的扩展。...LINQ表达式是对常用扩展方法在语法层面上的简化,LINQ表达式有着更好的可读性,在编译时LINQ表达式会被转化为对扩展方法的调用。...两个接口 在LINQ中,一个查询表达式被编译为表达式树或者委托,查询结果为IEnumerableT>类型则被编译为委托,查询结果是IQueryable或IQueryableT>类型则被编译为表达式树...System.Linq.IQueryableT> 在执行查询操作时,IQueryable先在服务器端进行过滤操作(如果有的话),然后再将数据放到本地内存中。...工具推荐 LINQ Pad是一款轻量级的数据查询工具,在LINQ Pad中可以使用LINQ表达式、扩展方法、SQL语句等对数据库进行操作,简单易用功能强大。 ?

    2.7K30

    .NET深入解析LINQ框架(五:IQueryable、IQueryProvider接口详解)

    那么在LINQ中来说,我们无法通过一个方法多次调用来产生我们想要的表达式树,一个Where查询表达式扩展方法可能不仅仅是被LINQ查询表达式所使用,还有可能被ORM的入口方法所使用,比如Update更新的时候就需要...在LINQ中的查询表达式与查询方法其实是一一对应的,扩展方法是纵向的概念,而LINQ查询表达式是横向的,其实两者属于对应关系。...详情可以参见本人的“NET深入解析LINQ框架(四:IQueryable、IQueryProvider接口详解)”一文; 3】.LINQ查询表达式和链式查询方法其实都是空壳子 LINQ的真正意图是在方便我们构建表达式树...对于ExpressionT>的编译方式是编辑器帮我们生成好的,在运行时我们只管获取ExpressionTree就行了。...LINQ的查询表达式是通过扩展方法横向支撑的,你不用LINQ也一样可以直接使用各个扩展方法,但是那样会很麻烦,开发速度会很慢,最大的问题不在于此,而是没有统一的查询方式来查询所有的数据源。

    1.1K30

    了解LINQ

    实际上,能够被foreach的对象,一定是实现了带有返回值的IEnumerator的GetEnumerator()方法的接口,而.NET内置的该接口则是IEnumerable,一般指的是IEnumerable...的对象就是一个实现了IEnumerable的可被枚举的集合 LINQ的基本用法 扩展方法在LINQ的应用:LINQ的流式语法 LINQ的方法一般都是通过扩展方法了扩展的,就如最常用的几个,Where,Any...就是因为LINQ就是为了简单的能够处理复杂集合的数据,那么扩展方法就能够实现较为简单的链式查询,例如: var result= animals.MyWhere(t => t is "Cat" or "Dog...,实际上在返回result1和result2,就是通过IQueryProvider不断地在拼接表达式树,而最后通过foreach或者ToList等操作的时候,则才是真正调用Execute方法执行当前的IQueryable...里的那个表达式树属性Expression,而像LINQ To Sql或者是EFCore等需要IQueryable这种解释型的就是去实现了IQueryProvider里面的方法 参考 《C#7.0核心技术指南

    89920

    C#3.0新增功能09 LINQ 基础02 LINQ 查询简介

    查询操作的三个部分 所有 LINQ 查询操作都由以下三个不同的操作组成: 获取数据源。 创建查询。 执行查询。 下面的示例演示如何用源代码表示查询操作的三个部分。...支持 IEnumerableT> 或派生接口(如泛型 IQueryableT>)的类型称为可查询类型。 可查询类型不需要进行修改或特殊处理就可以用作 LINQ 数据源。...下例中,Customers 表示数据库中的特定表,而查询结果的类型 IQueryableT> 派生自 IEnumerableT>。...但基本规则很简单:LINQ 数据源是支持泛型 IEnumerableT> 接口或从中继承的接口的任意对象。...有关详细信息,请参阅 LINQ 中的查询语法和方法语法。 查询执行 延迟执行 如前所述,查询变量本身只存储查询命令。 查询的实际执行将推迟到在 foreach 语句中循环访问查询变量之后进行。

    3.5K30

    IEnumerable和IQueryable区分

    LINQ查询方法一共提供了两种扩展方法,在System.Linq命名空间下,有两个静态类:Enumerable类,它针对继承了IEnumerableT>接口的集合进行扩展;Queryable类,针对继承了...IQueryableT>接口的集合进行扩展。...我们会发现接口IQueryableT>实际也是继承了IEnumerableT>接口的,既然这样微软为什么要设计出两套扩展方法呢?...针对LINQ to OBJECTS 时,使用Enumerable中的扩展方法对本地集合进行排序和查询操作,查询参数接受的是Func,Func叫做谓语表达式,相当于一个委托。...针对LINQ to SQL时,则使用Queryable中的扩展方法,它接受的是Expression。 那么,到底什么时候使用IQueryableT>,什么时候使用IEnumerableT>?

    92320

    .NET深入解析LINQ框架(三:LINQ优雅的前奏)

    对于IEnumerableT>类型的查询表达式方法都知道它的执行是不会直接接受ExpressionT>类型对象的,那么动态LINQ是否能工作于IEnumerableT>接口?...其实可以的,有个很隐蔽的窍门隐藏在IQueryableT>扩展方法对象Queryable中,也就是AsQueryableT>方法,它返回的是一个实现了IQueryableT>接口的EnumerableQuery...很多人还一直咬着.NET不能跨平台,不能支持动态对象,不支持非托管等等理由来排斥它,然而他们所不知的是.NET已经悄无声息的做出来一大举动,那就是在静态语言运行时上嵌入动态语言运行时环境。...,提供基本原型,然后根据用户自己的思维方式构建任意对象树。...后面我们就来详细的讲解如何扩展IQueryableT>、IQueryableProviderT>两个重量级接口,只有他们两个才能让我们和LINQ对话,这两个接口还是很神秘的。

    1.7K20

    Entity Framework 的一些性能建议

    执行的时机是用到这个表达式结果的时候才去执行。 在公司码程序的时候,我看到好多同事用EF,写完查询喜欢直接调用ToList()方法。有时候这会造成很大的性能问题。...IQueryable, IEnumerable 在这两个接口的选择上,我偏向使用IQueryable。...大部分时候这两个接口在使用上的表现都是一致的,但如果你要做的是一个不确定的查询,意思是这个查询表达式不是一次性确定的,对于它的结果可能由别的类来选择到底select哪些东西,这时候就要用IQueryable...在MSDN论坛上也有个比较直观的答案: IQueryable returns a "queryable" that is a query you could still be enriched before...C#里的Count有两种。Enumerable.Count()是方法,List.Count是属性。一旦一个东西变成了List,你再去Count,就必定是在内存里进行的了。

    1.7K30

    C#规范整理·集合和Linq

    在查询中使用Lambda表达式# LINQ实际上是基于扩展方法和Lambda表达式的,理解了这一点就不难理解LINQ。...13.区别LINQ查询中的IEnumerable<T>和IQueryable<T># LINQ查询方法一共提供了两类扩展方法,在System.Linq命名空间下,有两个静态类:Enumerable类,它针对继承了...稍加观察我们会发现,接口IQueryable<T>实际也是继承了IEnumerable<T>接口的,所以,致使这两个接口的方法在很大程度上是一致的。那么,微软为什么要设计出两套扩展方法呢?...注意 在使用IQueryable<T>和IEnumerable<T>的时候还需要注意一点,IEnumerable<T>查询的逻辑可以直接用我们自己所定义的方法,而IQueryable<T>则不能使用自定义的方法...在使用IQueryable<T>查询的时候,如果使用自定义的方法,则会抛出异常。 13.使用LINQ取代集合中的比较器和迭代器# LINQ提供了类似于SQL的语法来实现遍历、筛选与投影集合的功能。

    22730

    【源码解读(二)】EFCORE源码解读之查询都做了什么以及如何自定义批量插入

    IDbSetInitializer     在DBContext构造函数调用ServiceProviderCache.Instance.GetOrAdd的方法之后,去获取了一个IDbSetInitializer...,实际上就是去调用我们的Setter方法,去创建我们的DBSet对象。...(10).ToList();这个语句的执行,都经历了哪些,众所周知,DBSet实现了IQueryable的接口,所以我们在调用的时候是可以使用Queryable里面的扩展方法的,例如上面的语句中,Take...方法,在此之前会先获取一下状态管理。...,unchanged,分别对应实体的状态,通过去获取存在不存在当前的Entry,在什么状态,不存在的话就去查找runtimetype是否存在,然后调用SetEntityState方法,内部通过IStateManager

    38950

    在LINQ to SQL中使用Translate方法以及修改查询用SQL

    老赵在最近的项目中使用了LINQ to SQL作为数据层的基础,在LINQ to SQL开发方面积累了一定经验,也总结出了一些官方文档上并未提及的有用做法,特此和大家分享。   ...如果我们在获取Item列表时把Introduction一起获得的话,那么应用服务器和数据库服务器之间的数据通信量将会成百甚至上千地增长了。...,意思就是不能在LINQ to SQL中显式构造Demo.Item对象。   事实上在RTM之前的版本中,以上的语句是能运行通过的——我是指通过,不是正确。...而这次扩展的关键在于新的ExecuteQuery方法,它接受一个IQueryable类型的对象作为参数,返回一个范型的List。...以上扩展所受限制   以上的扩展并非无可挑剔。由于Translate方法的特点,此类做法都无法充分发挥LINQ to SQL查询的所有能力——那就是所谓的“LoadWith”能力。

    4.9K50

    C#3.0新增功能09 LINQ 标准查询运算符 01 概述

    共有两组 LINQ 标准查询运算符,一组作用于类型 IEnumerableT> 的对象,另一组作用于类型 IQueryableT> 的对象。...此外,多个标准查询运算符方法作用于那些基于 IEnumerableT> 或 IQueryableT> 的类型外的类型。...返回序列的方法会延迟查询执行,并返回一个可枚举的对象。 对于在内存中集合上运行的方法(即扩展 IEnumerableT> 的那些方法),返回的可枚举对象将捕获传递到方法的参数。...在枚举该对象时,将使用查询运算符的逻辑,并返回查询结果。 与之相反,扩展 IQueryableT> 的方法不会实现任何查询行为,但会生成一个表示要执行的查询的表达式树。...源 IQueryableT> 对象执行查询处理。 可以在一个查询中将对查询方法的调用链接在一起,这就使得查询的复杂性可能会变得不确定。

    68820
    领券