首页
学习
活动
专区
圈层
工具
发布

.NET 2.0运行时的LINQ

请参见此处:.NET 2.0上的LINQ支持 创建一个新的控制台应用程 仅将System和System.Core保留为引用的程序集 为System.Core将Copy Local设置为true,因为它在...到对象依赖于IEnumerable扩展和几个委托声明(中Action和Func家庭),并已在实施LINQBridge(如mausch提到).LINQ to XML和LINQ to DataSets依赖于...但是,您必须实现一些自己的LINQ方法. LINQ使用合成转换将查询转换为可执行代码.基本上,它将采用这样的代码: ?... end function 表达式树版本使您能够获得提供给子句的表达式的树表示,然后可以使用它们来生成SQL代码(或者您想要的任何其他内容)....您可以在大约一天左右的时间内创建自己的LINQ对象版本.这一切都很直接. 如果你想使用DLINQ,那么事情会有点困难. 收藏 | 0点赞 | 0打赏

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

    《ASP.NET Core 与 RESTful API 开发实战》-- (第6章)-- 读书笔记(下)

    中添加属性 public string SortBy { get; set; } = "Name"; 接下来,在 AuthorRepository 的 GetAllAsync 方法中,使用 OrderBy 子句来实现查询...的 OrderBy 扩展方法不支持直接使用字符串,当资源支持多个排序字段时,一一判断比较繁琐,而且在进行后续排序时,还应该使用 ThenBy 子句,使得判断更加复杂,幸运的是可以借助第三方库 System.Linq.Dynamic.Core...实现动态 LINQ 查询 System.Linq.Dynamic.Core 除了支持直接使用属性名排序之外,还支持多属性排序,多个属性之间使用逗号隔开,每个属性默认以升序排序,若要使用降序排序,则应在属性名后添加...库中的 OrderBy 对 IQueryable 对象排序,并返回排序后的结果 接着,修改 AuthorRepository 的 GetAuthorsAsync 方法中的返回结果语句 //var orderedAuthors...context.Exception.ToString()); Logger.LogCritical(sb.ToString()); } } } 最后将它添加到

    86910

    LINQ鲜为人知的7个秘密:从表达式树到并行查询的深度探索

    他的目标是解决C#面向对象世界与数据库关系世界之间的"阻抗失配"。最终诞生的LINQ与其说是发明,不如说是数十年函数式编程与数据库理论的完美融合,让数百万C#开发者得以受益。 2....IQueryable不存储数据,它存储的是"配方" 这可能是最关键也最容易被误解的概念。当你针对数据库编写LINQ查询时,通常操作的是IQueryable。...许多开发者将其视为内存中的IEnumerable,但二者有本质区别: • IEnumerable是数据流,你可以遍历它 • IQueryable是表达式树,它是查询的"配方"或蓝图 当你对IQueryable...这就是为什么在IQueryable查询中使用本地C#方法会失败——SQL转换器根本不知道你的C#方法要做什么。...而如果在where和select子句中重复相同计算,就会做双倍工作。

    19000

    C#3.0新增功能09 LINQ 基础01 语言集成查询

    语言集成查询 (LINQ) 是一系列直接将查询功能集成到 C# 语言的技术统称。 数据查询历来都表示为简单的字符串,没有编译时类型检查或 IntelliSense 支持。...LINQ 系列技术提供了针对对象 (LINQ to Objects)、关系数据库 (LINQ to SQL) 和 XML (LINQ to XML) 的一致查询体验。...在 C# 中可为以下对象编写 LINQ 查询:SQL Server 数据库、XML 文档、ADO.NET 数据集以及支持 IEnumerable 或泛型 IEnumerable 接口的任何对象集合...一些查询操作(如 Count 或 Max)没有等效的查询表达式子句,因此必须表示为方法调用。 可以各种方式结合使用方法语法和查询语法。 有关详细信息,请参阅 LINQ 中的查询语法和方法语法。...IQueryable 和 IQueryable 查询编译为表达式树。 有关详细信息,请参阅表达式树。

    2.3K10

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

    下面我们将重点分析Linq to Provider,这样我们才能真正的对LINQ进行高级应用。...IQueryable并非IEnumerable对象,无法实时的做出处理然后将结果返回给下一个方法接着执行。那么它如何将片段性的执行方法串成一个整的、完整的查询?...这幅图重点是IQueryable对象的连续操作,大致原理是每次执行扩展方法的时候都会构造一个新的IQueryable,本次的IQueryable对象将包含上次执行的表达式树,以此类推就形成了一颗庞大的表达式树...这是问题的重点,对扩展方法、链式编程不熟悉的朋友很难将source能串联到之前方法所返回的IQueryable对象上。...3.3】.分段执行IQueryable中的子方法(Queryable中的扩展方法) 都知道Linq的查询是将一些关键字拼接起来的,行成连续的查询语义,这其中背后的原理文章上上下下也说过很多遍,我想也应该大致的了解了

    2.1K11

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

    最为常见的就是遍历树形结构的对象,如:XML,它的每个节点都是一样的对象,所以递归调用的方法也是同一个方法,只不过不断的调用将产生多个调用栈,最后在按照调用顺序的反向出栈就得出一个完整的数据结构。...IQueryable接口貌似是一个对象,但是它们都属于一个完整的IQueryable中的一员。N层对象体现在哪里?...这一节我将给出LINQ的核心的执行图,我们将很清楚的看见LINQ的最终表达式树的对象结构,它是如何构建一棵完整的树形结构的,IQueryable接口是怎么和IQueryProvider接口配合的,为什么...5】.IQueryable与IQueryProvider一对一的关系能否改成一对多的关系 IQueryable对象都有一个配套的IQueryProvider对象,在频繁的创建IQueryable的时候都会重新创建...ORM一直是我们比较喜欢去写的框架,这里就使用自定义的IQueryable来查询相应的对象实体。首先我们需要继承IQueryable接口来让LINQ能查询我们自己的数据上下文。

    1.5K30

    .NET深入解析LINQ框架(六:LINQ执行表达式)

    一:LINQ执行表达式 在研究LINQ的过程中,参考了很多技术文章还有技术书籍,毫无疑问的是Linq to Provider的调用入口都是将Lambda表达式解析成Expression表达式对象,...进行执行,并非我们所理解的那样将表达式Expression对象完全解析成等价的SQL,也就是说Expression并不是我们说看到的那样单纯,它具有双重上下文逻辑在里面。...之前我一直以为VS只负责将LINQ的表达式翻译成等价的扩展方法调用,后来发现VS为了满足我们在前期无法确定对象条件的情况下进行Where字句的拼接,允许我们在编写LINQ语句的时候带有逻辑判断表达式在里面...一般我们都会进行if的判断才行,因为我们都觉得Where后面的条件表达式是直接被解析成对应逻辑的SQL语句,所以只要拼接进去的都是被解析成SQL的Where子句。...1 IQueryable queryList = DbContext.TB_CX_TRUCK.AsQueryable();//初始化一个IQueryable对象 2 if (

    2K10

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

    下面我们将主要学习对象模型的相关知识,什么是对象模型?其实很多时候我们注重的是语言层面的学习而并没有将重点放在对象的设计原理上,导致学习成本的不断增加。...其实LINQ就是使用这种方式来作为它的查询原理的。这里将直接点题到LINQ的核心设计原理上。...关于链式查询方法也是一个对象设计问题,我们参见链式设计模式可以很自然的构建符合我们自己实际需求的链式查询方法,这一系列的查询方法的添加存在一个很大的问题就是无法动态的添加到要扩展的对象内部去。...另外一类LINQ支持的查询对象便是我们自定的数据源了,这类数据源的查询链式方法是由System.Linq.Queryable类提供的,如果我们使用LINQ查询表达式来查询System.Linq.IQueryable...组件开发人员首要的任务就是创建对象模型,该对象模型应该是真正数据源的抽象模型,以便于该对象可能成功的被放入到IQueryable中进行查询。

    2.9K30

    C#内建接口:IQueryable

    其主要用于 LINQ(Language Integrated Query)查询,它允许我们在编写类型安全的查询表达式时,将查询操作推迟到实际执行查询的时候,以便进行更有效的查询优化。...这意味着当我们在 IQueryable 对象上构建查询表达式时,查询不会立即执行,而是在实际需要结果时才会执行。这使得我们可以在编写查询时进行组合、筛选和排序等操作。...在 C# 中,常用的查询提供者是 Entity Framework(EF),它可以将 IQueryable 查询转换为适当的 SQL 查询语句,并与数据库进行交互以获取结果。...int[] numbers = { 1, 2, 3, 4, 5 }; //构建查询对象(注意:在此处还没有执行查询) IQueryable query = numbers.AsQueryable...对象,针对这个查询对象,我们用 Where 方法筛选出偶数,再使用 Select 方法将每个偶数乘以 10取这样一个结果。

    82110

    了解LINQ

    实际上,能够被foreach的对象,一定是实现了带有返回值的IEnumerator的GetEnumerator()方法的接口,而.NET内置的该接口则是IEnumerable,一般指的是IEnumerable...{ get; } bool MoveNext(); void Reset(); } Current:集合当前的对象...的对象就是一个实现了IEnumerable的可被枚举的集合 LINQ的基本用法 扩展方法在LINQ的应用:LINQ的流式语法 LINQ的方法一般都是通过扩展方法了扩展的,就如最常用的几个,Where,Any...的延迟执行:IQueryable 首先我们来看看IQueryable的接口定义: public interface IQueryable : IEnumerable {...里的那个表达式树属性Expression,而像LINQ To Sql或者是EFCore等需要IQueryable这种解释型的就是去实现了IQueryProvider里面的方法 参考 《C#7.0核心技术指南

    1.4K20

    .NET面试题系列 - LINQ to SQL与IQueryable

    名言警句 "理解IQueryable的最简单方式就是,把它看作一个查询,在执行的时候,将会生成结果序列。" - Jon Skeet LINQ to Object和LINQ to SQL有何区别?...LINQ to SQL可以将查询表达式转换为SQL语句,然后在数据库中执行。相比LINQ to Object,则是将查询表达式直接转化为Enumerable的一系列方法,最终在C#内部执行。...LINQ to Object的数据源总是实现IEnumerable(所以不如叫做LINQ to IEnumerable),相对的,LINQ to SQL的数据源总是实现IQueryable将查询表达式转换为SQL语句并不保证一定可以成功。 IQueryable 理解IQueryable的最简单方式就是,把它看作一个查询,在执行的时候,将会生成结果序列。...将程序员从对SQL语句的拼接(尤其是insert)中解放出来,它既容易错,又很难发现错误。现在插入的对象都是强类型的,就犹如插入一个List一样。

    2.2K10

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

    Enumerable.TakeWhileQueryable.TakeWhile 07 联接运算 联接两个数据源就是将一个数据源中的对象与另一个数据源中具有相同公共属性的对象相关联。...(C#) 匿名类型 构建联接和叉积查询 join 子句 如何:使用组合键进行联接 如何:联接不同文件的内容 (LINQ) (C#) 如何:对 join 子句的结果进行排序 如何:执行自定义联接操作 如何...:执行分组联接 如何:执行内部联接 如何:执行左外部联接 如何:从多个源填充对象集合 (LINQ) (C#) 08 数据分组 分组是指将数据分到不同的组,使每组中的元素拥有公共的属性。...标准查询运算符概述 (C#) group 子句 如何:创建嵌套组 如何:按扩展名对文件进行分组 (LINQ) (C#) 如何:对查询结果进行分组 如何:对分组操作执行子查询 如何:使用组将一个文件拆分成多个文件...Enumerable.AsEnumerable AsQueryable 将(泛型)IEnumerable 转换为(泛型)IQueryable。 不适用。

    12.7K20

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

    系列目录 【已更新最新开发文章,点击查看详细】 标准查询运算符 是组成 LINQ 模式的方法。...共有两组 LINQ 标准查询运算符,一组作用于类型 IEnumerable 的对象,另一组作用于类型 IQueryable 的对象。...Queryable 类定义了两种类似的方法 Cast(IQueryable) 和 OfType(IQueryable),这两种方法都作用于类型 Queryable 的对象...返回序列的方法会延迟查询执行,并返回一个可枚举的对象。 对于在内存中集合上运行的方法(即扩展 IEnumerable 的那些方法),返回的可枚举对象将捕获传递到方法的参数。...源 IQueryable 对象执行查询处理。 可以在一个查询中将对查询方法的调用链接在一起,这就使得查询的复杂性可能会变得不确定。

    97720

    C#3.0新增功能07 查询表达式

    内存中集合包含对象的序列。 从应用程序的角度来看,原始源数据的特定类型和结构并不重要。 应用程序始终将源数据视为 IEnumerable 或 IQueryable 集合。...select 子句 使用 select 子句可生成所有其他类型的序列。 简单 select 子句只生成类型与数据源中包含的对象相同的对象的序列。 在此示例中,数据源包含 Country 对象。...有关详细信息,请参阅 orderby 子句。 join 子句 使用 join 子句可基于每个元素中指定的键之间的相等比较,将一个数据源中的元素与另一个数据源中的元素进行关联和/或合并。...在 LINQ 中,联接操作是对元素属于不同类型的对象序列执行。 联接了两个序列之后,必须使用 select 或 group 语句指定要存储在输出序列中的元素。...还可以使用匿名类型将每组关联元素中的属性合并到输出序列的新类型中。下面的示例关联其 Category 属性与 categories 字符串数组中一个类别匹配的 prod 对象。

    2.9K10
    领券