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

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

微软最初的设计目的是为了解决对象/关系映射的解决方案,通过简单的使用类似T-SQL的语法进行数据实体的查询和操作。...集合初始化使用大括号的多行语法也很容易理解。类不具体的对象的数据赋值是相同的。 我想对代码有追求的朋友都会很喜欢这种语法,确实很优美。...要想获取匿名类型的各属性值只能通过反射的方式动态的获取运行时的属性对象,然后通过属性对象去获取到属性的值。...在.NET3.5框架的System.Linq.Expression命名空间中引入了以Expression抽象类为代表的一群用来表示表达式树的对象集。...在Parameters是所有参数的自读列表使用的是System.Collection.ObjectModel.ReadOnlyCollection泛型对象来存储。

1.8K31

ASP.NET MVC5高级编程 ——(7)LINQ to SQL

; LINQ 是一组语言特性和API,使得开发人员可以使用统一的方式编写各种查询。...查询的对象包括XML、对象集合、SQL Server 数据库等等。...例如: -- C# 中字符串用 string 表示 -- SQL 中字符串用 NVarchar/Varchar/Char 表示 SQL 编码体验落后: -- 没有智能感应 -- 没有严格意义上的强类型和类型检查...SQL 和 XML 都有各自的查询语言,而对象没有自己的查询语言 1.3 LINQ的组成 LINQ 主要包含以下三部分: LINQ to Objects 主要负责对象的查询 LINQ to XML...参数列表中的参数类型可以是明确类型或者是推断类型(var)。 如果是推断类型,则参数的数据类型将由编译器根据上下文自动推断出来。 如果参数列表只包含一个推断类型参数时,可以去掉括号: ? ?

2.5K30
您找到你想要的搜索结果了吗?
是的
没有找到

.NET3.5新特性,Lambda表达式

下面是这个系列的前2篇贴子: 自动属性对象初始化器,和集合初始化器 扩展方法 今天的贴子讨论另一个基础性的新语言特性:Lambda表达式。 什么是Lambda表达式?...在上面的例子里,我用第一个lambda来指定获取特定人时所用的过滤条件,用第二个lambda来指定在计算平均年龄时该用Person对象的哪个值。...但考虑一下你想要查询数据库里的数据的情形(下面的代码是使用Orcas中内置的LINQ到SQL对象关系映射器写成的) : ?...而我希望的是,LINQ到SQL的ORM将我上面的Lambda过滤条件翻译成SQL表达式,然后在远程的数据库里进 行过滤性查询。...编译器不会产生IL,而是会指派一个表达式树对象,然后我作为一个框架开发人员就可以用它来对相应的Lambda表达式进行分析,我想要的方式对其进行运算(譬如,我可以挑出表达式中的类型,名字和值等)。

1.7K80

优化OEA中的聚合SQL

:同时加载它每一个ProjectPBS的对象列表ProjectPBSPropertyValues,并把ProjectPBSPropertyValues按照外键PBSProperty的OrderNo属性进行排序...(其中,Order方法需要使用泛型方法指明类型是因为目前的实体列表都是非泛型的,不能进行类型推断。) 总体设计     本次设计,主要是以提高模块的易用性为目的。    ...其实在实际运用当中,这样的局限性在使用的时候并没有太大的问题,一是较多的使用场景不需要同时加载所有的,二是可以分两条线加载对象后,再使用对象进行数据的融合。..._items.AddLast(item); } } 而它包含的每一个元素 LoadOptionItem 则表示一个加载项,它主要包含一个属性的元数据,用于表示要级联加载的对象集合属性或者外键引用对象属性...= System.Linq.Expressions.Expression.Lambda>(body, pE, pEFK); var

1.6K70

ORM查询语言(OQL)简介--高级篇:脱胎换骨

所以我们会看到针对集合操作的扩展方法,有很多都要使用 => 的调用方式,而OQL没有使用Lambda,它是怎么获取到查询对应的表名称和字段名称的呢?它是怎么实现SQL查询的层次结构的呢?...,也不需要Lambda表达式,更不需要表达式树,就能够直接获取到要查询的表名称和字段名称,写法比Linq更简洁,处理速度更快速。...由于不同的情况使用属性字段的时机不一样,为了处理这些不同的情况加入了各种Case下的处理代码,比如将Select方法要使用属性字段名称保存到列表  selectedFields 中。...因此可能出现OQLCompare使用实体类在OQL中没有使用,从而产生错误的查询; OQLCompare中的的字段名与OQL缺乏相关性,因此只能通过“表名称.字段名称”这种形式来使用属性字段名,无法使用别名...Ver 5.0的解决办法: 在OQL对象上,定义一些方法供OQL的关联对象来访问需要的属性字段名信息: /// /// 从堆栈上只取一个字段名

2.4K70

C#3.0新增功能09 LINQ 基础08 支持 LINQ 的 C# 功能

下面的查询表达式获取一个字符串数组,字符串中的第一个字符对字符串进行分组,然后对各组进行排序。...假定一个类名为 Customer,具有公共 Name 和 Phone 属性,可以下列代码中所示使用对象初始值设定项: var cust = new Customer { Name = "Mike",...可以在此数据源上执行 LINQ 查询,并使用对象初始化来填充集合: var newLargeOrderCustomers = from o in IncomingOrders...Lambda 表达式 Lambda 表达式是一种内联函数,该函数使用 => 运算符将输入参数与函数体分离,并且可以在编译时转换为委托或表达式树。...在 LINQ 编程中,在对标准查询运算符进行直接方法调用时,会遇到 lambda 表达式。

1.9K30

盘点 .NET 比较流行的开源的ORM框架

支持 Join 查询、Union all 、Subquery 支持配置查询 支持 DbFirst 从数据库导入实体类,或使用生成工具。...您可以使用 Chloe.ORM 通过 lambda 查询 LINQ 之类的数据并执行任何操作(查询 | 组查询 | 聚合查询 | 插入 | 批量更新 | 批量删除)。...开发人员使用Linq语言,对数据库操作如同操作object对象一样省事。 EF有三种使用场景: 1、从数据库生成Class。 2、由实体类生成数据库表结构。...在架构上,它比 Dapper、Massive 或 PetaPoco 等微 ORM 高出一步,因为您使用 LINQ 表达式而不是魔术字符串,同时在代码和数据库之间维护一个薄抽象层。...更好的参数替换支持,包括从对象属性中获取命名参数。 通过使用 DynamicMethod 生成消除 Linq 和快速属性分配来获得出色的性能。 查询语言是好的 ole SQL。

3.9K41

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

前言 -为什么需要扩展 Linq 方法 Linq 在 .net 中使用是比较多的,而微软开发的 linq 相关函数无法满足实际项目开发中的需求,我们需要自己来扩展一些方法。...普通查询 对于 Linq 查询来说,Where 和 OrderBy 使用时需要直接点出来属性或者字段才行,如下所示: // 数据结构 public class ArticleTag { public...出来属性进行查询的,但是实际使用中,从前端传递过来的一般都是字符串 "Name",而在后端进行查询时,以目前方式是无法将属性的key写到where函数中,也就无法执行查询通过"Name"来过滤数据;如果通过...if...else 来判断,那么将会是一个非常大的工程量,每个实体上面有 m 个属性,而一个项目中有 n 张表,那么几乎需要 m*n个判断进行处理,非常的差劲,不利于后续扩展和维护。...(){ var articleTags = new List(); // 将属性key字符串传递进来就可以实现查询和排序,方便使用,PropertyName可以随意更改,

1.7K10

【深入浅出C#】章节 9: C#高级主题:LINQ查询和表达式

强大的查询能力: LINQ提供了丰富的查询操作符和方法,可以进行过滤、排序、投影、分组等多种查询操作。 面向对象查询: LINQ是面向对象的,可以对对象进行查询,而不仅限于关系数据库。...以下是一个使用方法语法的示例,从一个字符串列表中选择长度大于3的字符串并按长度升序排序: var strings = new List { "apple", "banana", "grape...LINQ to Entities:用于将实体数据模型与数据库连接起来,支持使用LINQ查询进行数据库操作。 LINQ to XML:用于处理XML数据,支持以LINQ方式查询和操作XML文档。...var result = collection.Skip(3); 6.2 使用LINQ对集合进行过滤、映射和排序 使用LINQ对集合进行过滤、映射和排序非常简单,只需使用LINQ的相应操作符即可。...Descendants:获取指定名称的所有元素。 Elements:获取指定名称的直接元素。 Value:获取元素的值。 Add:添加新元素或属性。 Remove:移除元素或属性

1K61

走进 LINQ 的世界

LINQ 通过提供一种跨数据源和数据格式使用数据的一致模型,简化了这一情况。在 LINQ 查询中,始终会用到对象。...在使用 group 子句结束查询时,结果采用列表列表形式。列表中的每个元素是一个具有 Key 成员及根据该键分组的元素列表对象。...在 LINQ 中,您不必像在 SQL 中那样频繁使用 join,因为 LINQ 中的外键在对象模型中表示为包含项集合的属性。...若要创建包含源元素的多个属性的元素,可以使用具有命名对象或匿名类型的对象初始值设定项。...查询将一个 Customer 对象序列用作输入,并只选择结果中的 Name 属性。因为 Name 是一个字符串,所以查询生成一个字符串序列作为输出。

4.5K30

2022年了有哪些值得推荐的.NET ORM框架?

它解决了对象和关系型数据库之间的数据交互问题,ORM的作用是在关系型数据库和业务实体对象之间作一个映射,这样我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象属性和方法...主要特点: 支持 CodeFirst 模式,即便使用 Access 数据库也支持数据迁移; 支持 DbFirst 模式,支持从数据库导入实体类,或使用实体类生成工具生成实体类; 支持 深入的类型映射,比如...PgSql 的数组类型等; 支持 丰富的表达式函数,以及灵活的自定义解析; 支持 导航属性一对多、多对多贪婪加载,以及延时加载; 支持 读写分离、分表分库、过滤器、乐观锁、悲观锁; 支持 MySql/...查询接口类似于 LINQ。您可以使用 Chloe.ORM 通过 lambda 查询 LINQ 之类的数据并执行任何操作(加入查询 | 组查询 | 聚合查询 | 插入 | 批量更新 | 批量删除)。...在架构上,它比 Dapper、Massive 或 PetaPoco 等微 ORM 高出一步,因为您使用 LINQ 表达式,而不是魔术字符串,同时在代码和数据库之间维护一个薄抽象层。

5.7K11

C#历来语法特性总结

lambda不同的是,使用delegate创建匿名函数可以省略参数列表,可将其转换为具有任何参数列表的委托类型。...C# 3推出了很多强大的功能,如自动属性、扩展方法、隐式类型、LINQ,以及Lambda表达式。...任何Lambda表达式都可以转换为委托类型,表达式Lambda语句还可以转换为表达式树(语句Lambda不可以)。 匿名函数可以省略参数列表Lambda中不使用的参数可以使用弃元指定(C# 9)。...对象、集合初始化列表 从C# 3开始,可以在单条语句中实例化对象或集合并执行成员分配。...使用对象初始化列表,可以在创建对象时向对象的任何可访问字段或属性分配值,可以指定构造函数参数或忽略参数以及括号。

33840

Unity性能调优手册10C#优化:GC,对象池,forforeach,string,LINQ

这意味着每次重复循环时都要执行对Count属性的访问。数的越多对属性的访问次数进行计数,对属性的访问次数比例增加越多,根据访问次数的不同,负载变得不可忽略。...表示字符串的Char对象字符串GC。Alloc很容易在一次使用中出现。例如,使用字符连接操作符+连接两个字符串将导致创建一个新的字符串对象。...上一节中对对象使用也应该应用在这里,并且可能提前使用字符串应该是预先生成的字符串对象使用 然而,在游戏过程中,有时必须执行字符串操作和创建字符串对象。...在这种情况下,有必要为字符串预先生成一个缓冲区,并对其进行扩展,以便可以原样使用。...许多LINQ方法接受IEnumerable并返回IEnumerable,这个API设计允许使用方法链进行直观的描述。方法返回的实体IEnumerable是每个函数的类实例。

63310

编写高质量代码:改善C#程序的157个建议

编写高质量代码:改善C#程序的157个建议 2014-12-13 张阳 推荐: 4 难度: 3 ? 这本书汇集了C#编写中的一些建议、注意事项和小技巧,为了温故知新,又拿出来翻看了一遍。...拼装多个字符串时,使用 StringBuilder。 类型转换的方法 类型转换运算符(operator重载),例如 float j=0; int i = (int)j;。...总是使用TryParse,不使用Parse 恰当使用Nullable类型 如果数据库的字段可为null,那么对应的C#实体属性也应当可以为null。使用int?...使用集合初始化器对集合进行初始化 数组:string[] list = { "1", "2", "3" }; 列表:List list = new List()...使用匿名类型存储LINQ查询结果 在查询中使用Lambda表达式 实际上我只用Lambda表达式,因为个人认为LINQ的查询语法相当怪异,像SQL又有不同,看上去很别扭。

2.5K30

在VS中调试LINQ(Lambda)

注意和前提 LinqLinq to object 对于Linq to object,只有集合对象是 IEnumerable 时,才能命中到Linq里的lambda表达式,IQueryable是不行的。...操作步骤 有2种方法: 光标移动到箭头=>后面的lambda语句(方法体)内,F9,这个lambda语句的断点就打上了。其他的lambda语句操作类似。...前2个框可以点开看看一些选择项,第3个框可以输入一些代码,代码里可以使用变量/方法,会有智能提示的。 注意:lambda表达式的参数没有提示,需要手动输入参数名和参数的属性/方法。...我们可以在输入框里输入一些字符串字符串里可以使用变量/有返回值的方法,不过它们必须要放在 {} 里,会有智能提示的。 注意:lambda表达式的参数没有提示,需要手动输入参数名和参数的属性/方法。...有4种方法: VS里使用【快速监视】 VS里使用断点设置里的【操作】 使用OzCode 使用LinqPad VS里使用【快速监视】 首先在整个语句上设置断点,当程序运行到该断点时,在集合对象上右键->快速监视

4.6K30

Rafy 框架 - 使用 SqlTree 查询

查询中使用的是实体类型(Chapter)和实体的托管属性(Chapter.NameProperty)来定义表和字段。 更多的查询语法示例,见本节后面的更多示例。...当开发者在使用 Linq 查询时,编译器其实是生成一组对象来表示一棵表达式树,而 Rafy 框架会解析这棵树,生成更加底层的 SqlTree 对象,才交给执行引擎去生成真正的 Sql 语句并最终执行。...Linq 的 Labmda 语法中的属性表达式(e.Name)需要绑定具体的实体类型(Book e),这导致了必须使用反射去生成表达式树,才能编写通条蚁。...但是,SqlTree 的语法是基于托管属性框架的,它不需要使用确切的实体属性表达式,只需要使用托管属性的运行时对象 IManagedProperty 即可(Book.NameProperty)。...例如:当使用 幽灵插件 对所有幽灵数据进行自动过滤时,如果开发者使用手工编写的 Sql 语法进行查询,那么自动过滤功能无效,需要开发者自己进行幽灵数据的过滤

2.4K70

C# Lambda表达式详解,及Lambda表达式树的创建

您可使用匿名方法来忽略参数列表。 这意味着匿名方法可转换为具有各种签名的委托。 这对于 Lambda 表达式来说是不可能的。...如果出现这种情况,你可以以下示例中所示方式显式指定类型: (int x, string s) => s.Length > x 使用空括号指定零个输入参数: () => SomeMethod() 2、语句...然后调用LINQ的first方法,查询出来长度大于7的第一个结果,看到了吧,这里用的就是Lambda表达式, 如果我们自己写,还要写循环遍历集合,然后判断字符串长度是否大于7,起码要写四五行代码,而这里只要一行就够了...,而且LINQ也要写很长。...2013替换成为2014,当然还可以是将其他字符串替换城任何内容,或者是截取,连接等等,完全由我们传入的Lambda表达式决定,到了这里感觉到Lambda表达式的强大了吧。

81910

2022年了有哪些值得推荐的.NET ORM框架?

它解决了对象和关系型数据库之间的数据交互问题,ORM的作用是在关系型数据库和业务实体对象之间作一个映射,这样我们在具体的操作业务对象的时候,就不需要再去和复杂的SQL语句打交道,只需简单的操作对象属性和方法...主要特点: 支持 CodeFirst 模式,即便使用 Access 数据库也支持数据迁移; 支持 DbFirst 模式,支持从数据库导入实体类,或使用实体类生成工具生成实体类; 支持 深入的类型映射...,比如 PgSql 的数组类型等; 支持 丰富的表达式函数,以及灵活的自定义解析; 支持 导航属性一对多、多对多贪婪加载,以及延时加载; 支持 读写分离、分表分库、过滤器、乐观锁、悲观锁...查询接口类似于 LINQ。您可以使用 Chloe.ORM 通过 lambda 查询 LINQ 之类的数据并执行任何操作(加入查询 | 组查询 | 聚合查询 | 插入 | 批量更新 | 批量删除)。...在架构上,它比 Dapper、Massive 或 PetaPoco 等微 ORM 高出一步,因为您使用 LINQ 表达式,而不是魔术字符串,同时在代码和数据库之间维护一个薄抽象层。

3.8K20

带你了解C#每个版本新特性

Lambda表达式 实际上是一个匿名方法,Lambda表达的表现形式是:(参数列表)=>{语句},看一个例子,创建一个委托实例,获取一个string类型的字符串,并返回字符串的长度。...Lambda表达式树 是.NET3.5中提出的一种表达方式,提供一种抽象的方式将一些代码表示成一个对象树。...要使用Lambda表达式树需要引用命名空间System.Linq.Expressions,下面代码构建一个1+2的表达式树,最终表达式树编译成委托来得到执行结果: Expression a = Expression.Constant...>(add).Compile(); Console.WriteLine(fAdd()); //3 LambdaLambda表达式树为我们使用Linq提供了很多支持,如果我们在做的一个管理系统使用了...Linq To Sql,在列表页会有多个条件来进行数据的筛选的功能,这时就可以使用Lambda表达式树来进行封装查询条件,下面的类封装了And和Or两种条件: public static class

3.5K20

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

那么很大一部分应用场合中我们需要根据用户的选择来查询数据源,以往我们都是通过判断的方式来拼接查询的SQL字符串,但是现在我们面对是强类型的LINQ查询,是否可以很方便的进行类似查询。...其实动态LINQ查询所能执行的最关键的因素在于Expression对象是可以被动态编译成可以执行的委托对象,委托对象是完全可以被直接使用的可执行代码段,这就为动态LINQ查询提供了基础。...为什么需要动态LINQ查询,上面说过问题出在我们没办法在运行时再去编写Lambda表达式了,都知道Lambda表达式到最后就是被编译成Expression表达式树对象,所以我们可以在运行时自己动态的构建...很明显的例子就是当我们定义一个数据类型的对象时,无法再在后期运行时对它进行其他类型的使用,看一个简单的例子: 1 dynamic obj = 1;//整形 2 obj = "1";//字符串...,不过目前还不是很成熟,动态对象的成员没有智能提示,应该是还没有被大面积使用起来,以后肯定也是一大美餐; 总结:LINQ框架的基本使用原理就全部结束了,后面我们就来学习如何能让LINQ查询我们自定义的数据源

1.6K20
领券