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

Linq to Sql中Single写法不当可能引起的数据库查询性能低下

场景:需要从T_User表中返回指字条件的某条记录的某一个字段 在Linq中有二种理论上都行得通的写法,见下面的代码: Code using (dbUserDataContext db = new dbUserDataContext...[F_ID] = @p0',N'@p0 uniqueidentifier',@p0='00000000-0000-0000-0000-000000000001' //这才是我们想要的语句,即仅查询一个字段...("00000000-0000-0000-0000-000000000001")).Select(c => c.F_ID).Single(); 但观察最终提交到sqlserver的语句发现,第一种写法生成的语句返回了大量我们并不需要的字段...前几天,看到园子里有N多人说Linq如何如何差,甚至说linq要淘汰之类,感到很滑稽,技术本身并无问题,看你怎么用了,vb也能弄出很不错的系统,就象本文所提的内容,对linq有成见的人,可能会说:"linq...真烂,这么不智能,很傻很天真";而真正用linq的人,也许会说:"原来如此,以后我们应该用正确的写法,以避免因疏忽导致的性能问题"--生活很美好,快乐自己找,关键在于用什么角度去看,呵呵

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

    金三银四面试:C#.NET面试题中高级篇5-Linq和EF

    使用Code First模式进行EF开发时开发人员只需要编写对应的数据类(其实就是领域模型的实现过程),然后自动生成数据库。...它不会影响生成的SQL,但它可以令系统少维护很多数据,从而提高性能 5).使用Reshaper等工具,它可能会在你写出较差的代码时给出提醒 ---->详解 5.什么是IEnumerable?...LINQPad支持使用SQL或C#语句(点标记或查询表达式)进行查询。...你也可以通过点击橙色圈内的各种不同格式,看到查询表达式的各种不同表达方式: Lambda:查询表达式的Lambda表达式版本, SQL:由编译器转化成的SQL,通常这是我们最关心的部分, IL:IL语言...LINQ to SQL可以将查询表达式转换为SQL语句,然后在数据库中执行。相比LINQ to Object,则是将查询表达式直接转化为Enumerable的一系列方法,最终在C#内部执行。

    4.2K30

    表达式树

    在C#中,表达式树使在编译时表达式的结构和操作被保留下来,而不是像通常的.net代码那样被直接编译成IL。这使得你可以在运行时操作这些表达式或将它们转换成其他形式。...这种技术是.NET Framework中LINQ的基础,特别是在使用LINQ to SQL和LINQ to Entities时,因为它允许在运行时将LINQ查询表达式转换为SQL查询。...然后,我们把这个表达式树转换为一个Lambda表达式,并且编译并运行这个Lambda表达式,输出其结果。 反射与表达式树 在.NET中,表达式树和反射都可以用来在运行时动态地生成和执行代码。...表达式树可以用于创建LINQ查询:LINQ查询实际上就是表达式树。当你写一个LINQ查询时,编译器实际上是在后台创建一个表达式树。...这个表达式树然后可以被LINQ提供者(如Entity Framework)用来生成和执行相应的SQL查询。 5.

    31620

    【DB笔试面试608】在Oracle中,如何使用STA来生成SQL Profile?

    ♣ 题目部分 在Oracle中,如何使用STA来生成SQL Profile? ♣ 答案部分 利用STA对语句进行优化后,STA会对语句进行分析,采用最优的优化策略,并给出优化后的查询计划。...这个时候就可以利用Sql Profile,将优化策略存储在Profile中,Oracle在构建这条语句的查询计划时,就不会使用已有相关统计数据,而使用Profile的策略,生成新的查询计划。...这里要特别提到的是category这个参数,你可以通过设置这个参数,制定特定会话使用这个profile。在10g中,每个会话都有一个新参数SQLTUNE_CATEGORY,他的默认值是DEFAULT。...也为FOR_TUNING时,才会使用这个porfile。...并且在查询计划中还有一些附加信息,表明这个语句是采用了“SYS_SQLPROF_0154e728ad3f0000”这个Profile,而不是根据对象上面的统计数据来生成的查询计划。

    2.7K20

    在 SQL 中,如何使用子查询来获取满足特定条件的数据?

    在 SQL 中,可以使用子查询来获取满足特定条件的数据。子查询是嵌套在主查询中的查询语句,它返回一个结果集,可以用来过滤主查询的结果。...下面是使用子查询来获取满足特定条件的数据的一般步骤: 在主查询中使用子查询,将子查询的结果作为条件。 子查询可以在主查询中的 WHERE 子句、FROM 子句或 HAVING 子句中使用。...子查询可以返回单个值或多个值,具体取决于使用的运算符和子查询的语法。 以下是一些示例: 使用子查询在 WHERE 子句中过滤数据: SELECT column1, column2, ......FROM (SELECT column FROM table WHERE condition) AS temp_table; 使用子查询在 HAVING 子句中过滤数据: SELECT column1,...FROM table GROUP BY column1 HAVING column1 > (SELECT AVG(column1) FROM table); 请注意,子查询的性能可能会较低,因此在设计查询时应谨慎使用

    23910

    C#规范整理·集合和Linq

    在查询中使用Lambda表达式# LINQ实际上是基于扩展方法和Lambda表达式的,理解了这一点就不难理解LINQ。...针对LINQ to OBJECTS时,使用Enumerable中的扩展方法对本地集合进行排序和查询等操作,查询参数接受的是Func<>。Func<>叫做谓语表达式,相当于一个委托。...LINQ to SQL引擎最终会将表达式树转化成为相应的SQL语句,然后在数据库中执行。 那么,到底什么时候使用IQueryable<T>,什么时候使用IEnumerable<T>呢?...,它必须先生成表达式树,查询由LINQ to SQL引擎处理。...在使用IQueryable<T>查询的时候,如果使用自定义的方法,则会抛出异常。 13.使用LINQ取代集合中的比较器和迭代器# LINQ提供了类似于SQL的语法来实现遍历、筛选与投影集合的功能。

    22730

    .NET 中的表达式树(Expression Trees)

    引言什么是表达式树?表达式树是一种数据结构,用于表示代码的结构,并能在运行时生成和执行代码。表达式树的用途动态生成 LINQ 查询。代码分析和修改。运行时编程。...执行表达式树使用 Compile 方法将表达式树编译为可执行的委托。示例代码:执行之前创建的表达式树。表达式树的高级特性表达式树与 LINQ表达式树如何与 LINQ 查询结合使用。...示例:构建 LINQ 查询并将其转化为表达式树。延迟执行与表达式树解释延迟执行的概念和其在 LINQ 中的重要性。表达式树的应用场景动态 LINQ 查询生成实际项目中动态构建查询的需求。...示例:根据用户输入动态构建查询条件。ORM(对象关系映射)框架中的应用如何在 ORM 框架中利用表达式树生成 SQL 查询。示例:Entity Framework 中的实现。...总结表达式树的未来随着动态编程和代码生成需求的增加,表达式树的潜在应用领域。学习和实践鼓励读者尝试在实际项目中使用表达式树。

    2.3K00

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

    针对LINQ to OBJECTS时,使用Enumerable中的扩展方法对本地集合进行排序和查询等操作,查询参数接受的是Func。Func叫做谓语表达式,相当于一个委托。...LINQ to SQL引擎最终会将表达式树转化成为相应的SQL语句,然后在数据库中执行。   那么到底什么时候使用IQueryable,什么时候使用IEnumerable呢?...在LINQ to SQL的查询中,要尽量始终使用IQueryable。...,它必须先生成表达式树,查询由LINQ to SQL引擎处理。...建议31、在LINQ查询中避免不必要的迭代  无论是SQL查询还是LINQ查询,搜索到结果立刻返回总比搜索完所有的结果再将结果返回的效率要高。现在简单来创建一个自定义的集合类型来说明。

    96350

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

    Lambda表达式为编写匿名方法提供了更简明的函数式的句法,但结果却在编写LINQ查询表达式时变得极其有用,因为它们提供了一个非常紧凑的而且类安全的方式来编写可以当作参数来传递,在以后作运算的函数。...然后,我示范了你可以如何使用一些值来生成一个List集合的实例,然后使用由LINQ提供的新的Where和Average扩展方法来返回集合中的人的一个子集,以及计算这个集合中的人的平均年龄...但考虑一下你想要查询数据库里的数据的情形(下面的代码是使用Orcas中内置的LINQ到SQL对象关系映射器写成的) : ?...这么做效率极其不 高,对大数据库的扩缩性将是极差的。而我希望的是,LINQ到SQL的ORM将我上面的Lambda过滤条件翻译成SQL表达式,然后在远程的数据库里进 行过滤性查询。...当与Orcas中System.Linq命名空间下提供的内置标准查询扩展方法结 合使用时,它们提供了一个非常好的方式来对任何类型的数据进行查询和交互,同时还保持了对完整的编译时检查和intellisense

    1.8K80

    【SQL Server】在 SSMS 中 使用 生成 SQL 脚本 方式 实现 数据库 备份 还原 ( 数据备份操作 - 生成 SQL 脚本 | 数据还原操作 - 执行 SQL 脚本 )

    帮助开发人员和数据库管理员进行数据库管理、查询、优化和开发工作 ; 本篇博客介绍如何使用 SSMS 进行数据库备份 ; 使用的原理是 将数据库中的 数据 生成为 SQL 脚本 ( 几万条 SQL 语句...; 仅限架构 : 指的是 生成 建表的 SQL 语句 ; 仅限数据 : 指的是 生成 插入数据的 SQL 语句 , 执行前要删除数据库中的对应表 , 使用 TRUNCATE TABLE table_name...; 等待数据库表 生成脚本即可 ; 生成完毕后 , 点击 完成 按钮 ; 如果使用 固态硬盘 , 上述操作 几秒 就可以完成 , 如果使用机械硬盘 , 可能需要几分钟 ; 在保存位置 查看生成的脚本..., 右键点击 数据库 , 选择 " 新建查询 " , 然后 使用 truncate table [dbo]....脚本加载到 SSMS 中 ; 在脚本中 , 右键点击空白处 , 在弹出的菜单中选择 " 执行 " 选项 , 即可执行 等待执行完毕即可完成数据还原操作 ;

    43910

    PDF.NET 数据开发框架 许可限制 框架源码的获取

    ,设计了 OQL查询表达式。...; BLL层实体对象查询(OQL) DAL层SQL语句和.NET数据访问代码映射(查看 SQL-MAP 原理) 详细说来,框架还包含以下特色功能: 类似LINQ的支持ORM实体类查询的OQL表达式(有了...本框架 OQL的基本设计在LINQ或者说本人知道 LINQ之前,另外,.NET3.5框架才正式支持LINQ,而我们公司的一个产品却因为采用了3.5框架安装部署不方便成为市场和客服常常抱怨的理由。...技术限制        当前版本基于.NET2.0以上平台,不支持实体对象对应的数据库表外键关系,OQL表达式不支持多实体类查询,不支持SQL的统计求和分组等,如有这些 复杂查询需求,请使用SQL-MAP...SqlMapDAL 支持外部接口定义; 简化了支持多个SqlMap文件的处理方式; SQL-MAP支持复杂查询的分页; SQL-MAP改善了对存储过程的支持; OQL支持单行表达式语法(OQL.From

    1.2K60

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

    可使用相同的基本查询表达式模式来查询和转换 SQL 数据库、ADO .NET 数据集、XML 文档和流以及 .NET 集合中的数据。...查询表达式概述 查询表达式可用于查询并转换所有启用了 LINQ 的数据源中的数据。 例如,通过一个查询即可检索 SQL 数据库中的数据,并生成 XML 流作为输出。...查询表达式易于掌握,因为使用了许多熟悉的 C# 语言构造。 查询表达式中的变量全都是强类型,尽管在许多情况下,无需显式提供类型,因为编译器可以推断出。...在编译时,查询表达式根据 C# 规范规则转换成标准查询运算符方法调用。 可使用查询语法表示的任何查询都可以使用方法语法进行表示。 不过,在大多数情况下,查询语法的可读性更高,也更为简洁。...有关详细信息,请参阅 C# 语言规范和标准查询运算符概述。 通常,我们建议在编写 LINQ 查询时尽量使用查询语法,并在必要时尽可能使用方法语法。 这两种不同的形式在语义或性能上毫无差异。

    1.8K10

    使用ADO和SQL在Excel工作表中执行查询操作

    学习Excel技术,关注微信公众号: excelperfect 我们可以将存储数据的工作表当作数据库,使用ADO技术,结合SQL查询语句,可以在工作表中获取满足指定条件的数据。...在VBE中,单击菜单“工具——引用”,在“引用”对话框中,找到并选取“Microsoft ActiveX Data Objects 6.1 Library”,如下图1所示。 ?...在同一代码中,只需要连接数据库一次,接着可以执行多个查询操作,无需每次查询前都进行连接。...SQL查询语句为: query = "Select * from [" & wksData.Name _ & "$] Where 物品='苹果' " 在工作表wksData中查询物品为“苹果”的记录...图3 关于ADO对象模型及其属性和方法的应用,以及SQL查询语句语法,有兴趣的朋友可以参考相关资料进一步了解。

    4.7K20

    IEnumerable和IQueryable区分

    针对LINQ to OBJECTS 时,使用Enumerable中的扩展方法对本地集合进行排序和查询操作,查询参数接受的是Func,Func叫做谓语表达式,相当于一个委托。...针对LINQ to SQL时,则使用Queryable中的扩展方法,它接受的是Expression。 那么,到底什么时候使用IQueryable,什么时候使用IEnumerable?...至于这两段代码到底有什么区别,我们分别执行代码,在sql profiler里看一下生成的sql语句: 第一段代码效果: ?...虽然我们使用两条语句进行了查询,但最终只生成了一条SQL语句,将查询参数合并了。 第二代码效果: ? 这一次我们依然只看到一条SQL语句,但查询条件也只有一个,但两次查询的结果是一致。...原因在于Func直接会被编译器编译成IL代码,但是Expression只是存储了一个表达式树,在运行期作处理,LINQ to SQL最终会将表达式树转为相应的SQL语句,然后在数据库中执行。

    92320

    Rafy 框架 - 使用 SqlTree 查询

    本文介绍如何使用 Rafy 框架中的 Sql Tree 查询: 除了开发者常用的 Linq 查询,Rafy 框架还提供了 Sql 语法树的方式来进行查询。...使用场景 当您处于以下场景时,需要使用 SqlTree 查询: Linq 查询无法支持的一些场景。 Linq 查询目前只支持有限的一些操作符的解析,以及不太复杂的关系的分析。...当开发者在使用 Linq 查询时,编译器其实是生成一组对象来表示一棵表达式树,而 Rafy 框架会解析这棵树,生成更加底层的 SqlTree 对象,才交给执行引擎去生成真正的 Sql 语句并最终执行。...Linq 的 Labmda 语法中的属性表达式(e.Name)需要绑定具体的实体类型(Book e),这导致了必须使用反射去生成表达式树,才能编写通条蚁。...可以为扩展属性编写查询。 由于扩展属性写在额外的程序集插件中的,所以当无法通过 Linq 表达式进行查询。

    2.4K70

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

    1.3 LINQ查询和表达式的基本工作原理 LINQ(Language Integrated Query)查询和表达式的基本工作原理如下: 查询表达式的转换: 当你使用LINQ查询语法时,编译器会将这些查询表达式转换为标准的扩展方法调用...延迟执行: LINQ查询采用了延迟执行的概念,这意味着查询表达式并不会立即执行查询操作,而是在实际需要查询结果时才会执行。这有助于提高性能,因为只有在需要时才会访问数据源。...优化和提升: LINQ提供程序会尝试对查询进行优化,以提高查询性能。这可能包括筛选和投影操作的优化,以及在数据库查询中生成最优化的SQL查询语句。...二、LINQ基础 2.1 LINQ查询的语法和结构 查询表达式语法: 查询表达式使用类似于SQL的语法来编写查询。以下是一些常见的查询表达式关键字和示例: from: 指定数据源和范围变量。...匿名类型的属性名是从查询结果中的属性名推断出来的。然后我们在foreach循环中遍历查询结果并输出。 注意以下关键点: 匿名类型的类型名是由编译器生成的,并且在编译时是不可见的。

    2.3K61

    走进 LINQ 的世界

    目前需要注意的是,在 LINQ 中, 查询变量本身不执行任何操作并且不返回任何数据。 它只是存储在以后某个时刻执行查询时为生成结果而必需的信息。...在本例中,cust.City 是键。   在使用 group 子句结束查询时,结果采用列表的列表形式。列表中的每个元素是一个具有 Key 成员及根据该键分组的元素列表的对象。...在循环访问生成组序列的查询时,您必须使用嵌套的 foreach 循环。外部循环用于循环访问每个组,内部循环用于循环访问每个组的成员。   ...在 LINQ 中,您不必像在 SQL 中那样频繁使用 join,因为 LINQ 中的外键在对象模型中表示为包含项集合的属性。...当 select 子句生成除源元素副本以外的内容时,该操作称为“投影”。 三、使用 LINQ 进行数据转换   语言集成查询 (LINQ) 不仅可用于检索数据,而且还是一个功能强大的数据转换工具。

    4.6K30
    领券