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

C# .NET面试系列三:集合、异常、泛型、LINQ、委托、EF!

以下是创建自定义异常的基本步骤:1、创建自定义异常类创建一个类,并继承 System.Exception 或其派生类。你可以添加自己的构造函数、属性或其他方法。...6、使用合适的投影只选择需要的列,而不是选择整个对象。这可以通过使用 Select 进行投影,以减少返回的数据量。7、优化查询语句仔细编写LINQ查询,确保生成的查询语句是有效的。...如果需要了解集合的大小,必须转换为其他接口或类型,如 ICollection 或 Count 属性。...在使用EF进行数据操作时,了解实体对象的状态是很重要的。开发人员可以通过查看 Entry 属性来获取实体的状态,并据此采取相应的操作。...在实体类上使用 Table 属性,并传入数据库中的表名。

67310

Entity Framework 的一些性能建议

这是一篇我在2012年写的老文章,至今适用(没错,我说的就是适用于EF Core)。因此使用微信重新推送,希望能帮到大家。 自从我用了EF,每次都很关心是否有潜在的性能问题。...ToList()的问题 其实EF很多时候的性能问题都是关系到查询执行时机的。我们通常的意图是,首先建立一个查询表达式,只是build,而不execute。...但这时,很不幸的是,where语句中的条件并不是转换为native sql去执行的,它是在内存中筛选的。这是一个比较阴的性能问题。...紧跟其后的“.Posts”是Category对象的导航属性,EF会用lazy load去加载这个category所有的post,所以就生成了第二条SQL语句。...如果要让代码尽量去生成LINQ to SQL,有个很简单的原则,就是尽量用LINQ、Lambda表达式,这样EF才可能帮我们翻译。C#里的Count有两种。

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

    EF Core 性能陷阱:10个悄然扼杀应用速度的隐形杀手及破解之道

    尽管它拥有优雅的 API 和开发者友好的方法,但如果使用不当,EF Core 也可能成为性能瓶颈。...N+1 查询问题:无声的性能杀手 N+1 问题可以说是 EF Core 中最常见的性能陷阱。...它发生在你获取一个实体集合,然后为每个实体访问其关联属性时,这会导致 EF Core 执行一次查询获取初始集合,再为每个关联实体执行 N 次额外的查询。...客户端评估:当 EF Core 放弃治疗时 EF Core 有时无法将复杂的 LINQ 表达式转换为 SQL,于是退而求其次进行客户端评估(Client-Side Evaluation),将所有数据拉入内存进行处理...性能思维 EF Core 性能的关键不在于避免使用该框架——而在于理解你的 C# 代码如何转换为 SQL。每个 LINQ 表达式都有成本,有意识地规划数据访问模式将使你避免日后的性能灾难。

    47110

    Entity Framework Core 2.0 新特性

    使用所属类型与EF6中使用复杂类型类似,(PS:这里解释一下EF6中的复杂类型,复杂类型是允许在实体中组织标量属性的实体类型的非标量属性。像实体一样,复杂类型由标量属性或其他复杂类型属性组成。)...这些过滤器自动应用于涉及这些实体类型的任何LINQ查询,包括间接引用的实体类型,例如通过使用Include或直接导航属性引用。...通过这个特性 我们可以很方便的在linq中调用这些函数,并通过linq翻译成SQL 代码如下: public class BloggingContext : DbContext { [DbFunction...显式编译的查询API已经在以前版本的EF和LINQ to SQL中可用,以允许应用程序缓存查询的翻译,以便它们只能被计算一次并执行多次。...属性(注意,这里应该是可以扩展的,添加更多的数据库方法),EF Core可以使用它们来定义映射到数据库函数或操作符的方法,以便可以在LINQ查询中调用它们。

    5.1K90

    学习C#(一)

    当派生类从基类继承时,它会获得基类的所有方法、字段、属性和事件。若要更改基类的数据和行为,您有两种选择:可以使用新的派生成员替换基成员,或者可以重写虚拟的基成员。...如果基类定义了一个方法、字段或属性,则 new 关键字用于在派生类中创建该方法、字段或属性的新定义。...inher_1 = new Inherit_1();//子类 inher_1.print();//调用的是子类的方法 Inherit inher = (Inherit)inher_1;//父类--将派生类的实例强制转换为基类的实例...然后,派生类可以选择使用override 关键字而不是 new,将基类实现替换为它自己的实现 using System; using System.Collections.Generic; using...Inherit_1();//新建子类对象 inher_1.print();//调用子类方法 Inherit inher = (Inherit)inher_1;//强制转换为父类

    86540

    .NET 2.0运行时的LINQ

    启用LINQ的应用程序是否可以在仅安装了.NET 2.0运行时的计算机上运行? 从理论上讲,LINQ只不过是语法糖,而得到的IL代码应该与.NET 2.0中的代码相同....Stum..: 有一些"黑客"涉及使用3.5 Framework中的System.Core.dll使其与.net 2.0一起运行,但我个人不希望使用这样一个有点摇摇欲坠的基础....建立 将所有bin输出复制到仅安装.NET 2.0的计算机 跑 (需要.net 2.0 SP1,我不知道捆绑System.Core.dll是否违反了EULA) 重新分发System.Core.dll违反了...但是,您必须实现一些自己的LINQ方法. LINQ使用合成转换将查询转换为可执行代码.基本上,它将采用这样的代码: ?...dim q = from x in xs where x > 2 select x*4; 并将其转换为如下代码: ?

    1.4K10

    从ADO.NET到EF Core:一位架构师的深度踩坑指南与性能优化实战

    认知颠覆:EF Core不是简单的升级版 当EF Core首次发布时,我正为某物流公司重构单体架构转微服务项目。...早期教训告诉我:必须理解EF Core的内部机制。不能盲目相信它的查询优化能力。即便在写LINQ时,也要保持SQL思维。...核心认知:EF Core提供工具,但不提供流程规范。 LINQ反模式:把数据库当内存用 新手常犯的错误是像操作内存集合那样写LINQ:嵌套循环、条件中的投影、中途调用ToList()。...应对策略:将LINQ视为SQL而非内存操作。每个查询都要自问:"这能用SQL表达吗?" 值对象与影子属性的双面性 EF Core对值对象(Owned Types)的支持很出色,但需要精细配置。...教训:一个错误配置就能让整个模型对EF不可读。 影子属性(如LastUpdated)虽然方便,但缺乏编译时检查。我们曾因删除影子属性导致软删除功能静默失败。

    39710

    .NET面试题系列 - LINQ:性能

    注意当你返回IEnumerable时,你并没有开始遍历这个序列(只有当你强制LINQ执行时,才会执行这个返回IEnumerable的方法)。...我们知道foreach会强制LINQ执行,于是,我们可以想象这也是一个SELECT N+1问题的例子:先获得所有album(SELECT * FROM ALBUM),然后遍历,对每一个album的Title...LINQ:替代选择 在没有找到性能瓶颈之前,不要过早优化。 是否存在需要长时间运行的LINQ语句? 是否在数据库上取得数据,并运行LINQ语句?...LINQ的额外开销在于将lambda表达式转换为委托的形式,而foreach不需要。虽然这一点点额外开销对于普通的情况基本可以忽略,但如果重复一千万次,则性能可能会有较为明显的差异。...是否需要在数据库上筛选数据,并运行LINQ语句?如果是的话,考虑返回IQueryable,并考察编译器构建的中间SQL语句。 数据规模是否巨大?

    3.3K40

    EF Core的增删改查

    0.前言 到目前为止,我们看了一下如何声明EF Core的初步使用,也整体的看了下EF Core的映射关系配置以及导航属性的配置。 这一篇,我带大家分享一下,我在工作中需要的EF Core的用法。...不过如果有导航属性的话,在新增的时候,EF Core会自动检索导航属性的另一端是否需要新增到数据库中,如果需要新增的话,EF Core会自动标记为新增的。...而删除,如果在配置导航属性时,没有设置级联删除,删除当前元素,如果另一端的外键是可空类型的,并不会删除导航属性另一端的元素只会设置外键指向为NULL,如果另一端外键是不可空的,那么就会同时删除。...3.花样查询 EF Core 支持Linq查询,所以在查询的时候可以使用Linq进行。...EF Core在调用 ToList的时候,会将已调用的方法和Linq转换成SQL语句,并正式向数据库发起查询。如果出现了在Linq中调用三方方法或者自己写的工具方法的话,可能会提示不受支持。

    4.1K20

    每个 .NET 开发人员解决常见问题时都应该了解的 5 个 EF Core 功能

    通过将复杂的 SQL 查询转换为简单的 C# 代码,EF Core 消除了处理数据的许多麻烦。但问题是 — 许多开发人员没有充分利用 EF Core 提供的强大功能。...这样可以避免忘记在每个查询中添加过滤器的风险,并使您的代码更简洁。 关键字:EF Core 全局查询筛选器、EF Core 软删除、数据库筛选 2....Product 关键字:EF Core 影子属性、在 EF Core 中跟踪审核数据、实体框架核心审核跟踪 3....EF Core 通常会在每次使用时编译每个 LINQ 查询,这会增加开销。使用 Explicitly Compiled Queries,您可以重用查询的预编译版本以提高性能。...关键字:EF Core 值转换、在 EF Core 中将枚举转换为字符串、实体框架数据格式 Entity Framework Core 不仅仅是一个数据库工具,它还是一个强大的 ORM,其功能使开发数据驱动的应用程序更轻松

    1K10

    优化 EF Core 和 LINQ 以实现高性能应用程序

    实体框架核心(Entity Framework Core,简称 EF Core)是一款强大的对象关系映射(ORM)工具,它弥合了面向对象编程与关系型数据库之间的差距,而 LINQ 在.NET 中提供了强大的查询语法...本文将深入探讨针对 EF Core 和 LINQ 的有效优化技巧,展示好与不好的代码示例,讨论相关优势,并着重介绍那些有助于提升性能和可扩展性的特性。...对只读查询使用 AsNoTracking 这样做可以减少内存使用量,并加快只读数据的查询速度,因为 EF Core 不会跟踪实体的更改情况。...不佳示例:加载整个实体 var users = context.Users.ToList(); // 加载所有用户的所有属性 良好示例:只加载你需要的列 var userNames = context.Users.Select...var result = context.ActiveUsersByRole.ToList(); EF Core 和 LINQ 在.NET 应用程序开发中提供了无与伦比的便利性和高效性,但性能优化需要精心考量

    69510

    【深入浅出C#】章节 2:数据类型和变量:类型转换和类型推断

    这种转换需要在编译时或运行时检查基类实例是否实际上是派生类的实例,以避免类型不匹配的异常。 转换操作需要使用强制类型转换运算符()或as运算符。...引用类型之间的隐式转换: 从派生类向基类进行转换是隐式的。派生类的实例可以隐式转换为基类类型。...拆箱是将引用类型转换为值类型的过程。在拆箱操作中,引用类型中存储的值被提取出来,并转换为相应的值类型。拆箱操作需要进行类型检查和数据复制,因此也会带来一定的性能损耗。...LINQ 查询:使用 var 来存储查询结果,可以使代码更加简洁易读。 匿名类型:当创建一个包含一组属性的匿名类型时,使用 var 可以避免重复写出长长的类型名称。...临时数据传递:当需要传递一组相关的属性作为参数或返回值时,可以使用匿名类型。它可以方便地封装一组属性值,而不必为其创建一个专门的类。

    1K10

    .NET面试题系列 - LINQ to Object

    LINQ to Object将查询语句转换为委托。LINQ to Entity将查询语句转换为表达式树,然后再转换为SQL。...在面试时,大部分面试官都不会让你手写LINQ查询,至少就我来说,写不写得出LINQ的Join并没所谓,反正查了书肯定可以写得出来。但面试官会对你是否理解了LINQ的原理很感兴趣。...利用ToList强制执行LINQ语句 下面的代码和上面的区别在于我们增加了一个ToList方法。思考会输出什么? ? ToList方法强制执行了所有LINQ语句。...中,所有的产品的所有信息,但必须numberofstock属性大于25: From p in products where p. numberofstock > 25 select p SQL: select...对这两种写法的优劣有很多说法: 每个查询表达式都可以被转换为点标记的形式,而反过来则不一定。很多LINQ操作符不存在等价的查询表达式,例如Reverse,Sort等等。

    4.5K20

    Entity Framework 4.1 Code-First 学习笔记

    CodeFirst提供了一种先从代码开始工作,并根据代码直接生成数据库的工作方式。Entity Framework 4.1在你的实体不派生自任何基类、不添加任何特性的时候正常的附加数据库。...这是EF的默认约定,如果要修改关系表的名称,并修改对应的字段的名称,我们可以使用下面的代码来完成: modelBuilder.Entity() .HasMany(e => e.Orders...DbContext.Database.SqlQuery:这个方法将返回的数据集映射到相应的对象,而不去管这个对象是不是实体。重要的是 EF 不会跟踪返回的对象,即使他们是真正的实体对象。   ...另外一个 EF 映射管理的方法是使用 Entity SQL,这种方式是 EF 将实体模型转换为物理模型,然后将Linq查询添加到物理模型中,最后将物理模型转换为数据库存储的查询。...因此,我们可以通过从一个返回任何结果的简单查询开始,然后在其上应用 LINQ来得到有效的查询,而不需要在使用方查询整个表。

    2.3K10

    .NET Core 3.0 中的新变化

    EF Core 部分解决了此问题,具体方法是支持选择可转换为 SQL 的查询部分,再执行内存中剩余的查询。...在 EF Core 3.0 中,我们计划深入更改 LINQ 实现工作原理和测试方式,旨在提高它的可靠性(例如,避免破坏修补程序版本中的查询);让它能够将更多表达式正确转换为 SQL;在更多情况下生成高效查询...此提供程序将针对 Cosmos DB 中的 SQL API 启用大部分 EF Core 功能,如自动更改跟踪、LINQ 和值转换。...我们计划在 EF Core 3.0 中添加的其他功能包括,属性包实体(将数据存储在索引属性(而不是常规属性)中的实体);能够将数据库视图反向工程为查询类型;以及与新 C# 8.0 功能集成,如 IAsyncEnumerable...这些新 API 包括: Span:在 .NET Core 2.1 中,我们添加了 Span,这是类似数组的类型,允许以统一方式表示托管和非托管内存,并支持在不复制的情况下进行切片。

    6.2K10

    一步步学习EF Core(3.EF Core2.0路线图)

    嗯..下面就是微软爸爸觉得需要,但是还在研发 或者斟酌的东西:   3.1Query(查询) 改进的Linq翻译将使更多的查询成功执行,使得更多的逻辑在数据库(而不是内存中)中进行查询,从而减少不必要的数据库访问...从数据库更新模型允许以前从数据库逆向工程的模型将随着您对架构的更改而刷新。   3.3Modelling(实体模型) 复数/值类型是不具有主键的类型,用于表示实体类型上的一组属性。...改进的LINQ翻译(来自于GitHub上的各种问题) - 允许更多的查询成功执行,更多的逻辑在数据库中执行(而不是内存中),从而减少不必要地从数据库查询数据。...EF.Functions.Like()(#2850) - 允许将通配符的字符串匹配转换为SQL或在内存中进行匹配。...GroupBy翻译#2341 - 允许使用GroupBy()运算符翻译LINQ查询,该项目用于汇总要使用GROUP BY转换为SQL查询的函数。

    3.9K90
    领券