Entity FrameWork 中使用Lambda访问数据库性能优化
2014-05-07 10:16
477 查看
本文转载自博客园
点击打开链接
在使用Entity Framework 访问数据库时,我们经常使用Lambda表达式,但是如果不小心的话,很容易就掉到坑里了。比如下面的例子:用Lambda访问MSSqlServer中的NewsInfo表中id小于20的记录。
代码如下:
运行程序,程序工作正常。打开SQL Server Profiler 跟踪EF生成的SQL语句,结果如下:
这正是我们想要的SQL语句。下面我们将程序改一下,把Lambda表达式以参数的形式传递给一个方法GetNewsList(Func<NewsInfo, bool> lambda)。方法GetNewsList的代码如下:
Main()方法如下:
这时再次运行程序,程序工作正常,不过时间长了一些,用SQL Server Profiler跟踪,产生的SQL语句如下:
“坑”出现了,EF是直接从NewsInfo表中取出所有的数据到内存中,然后在内存中再做一次检索。显然,这样的方式在数据量小的时候并不太影响性能。但是在大数据量,高并发访问的时候,这种方式简直就是噩梦。
那么怎样改善呢?System.Linq.Expressions命名空间的Expression可以帮我们解决以上问题。修改后的GetNewsList()方法代码如下:
Main()方法不变。下面再次运行代码,并跟踪产生的SQL如下:
这下正常了。Expression<TDelegate>类可以以表达式目录树的形式将强类型 lambda 表达式表示为数据结构,从而在编译阶段产生我们想要的SQL代码。
点击打开链接
在使用Entity Framework 访问数据库时,我们经常使用Lambda表达式,但是如果不小心的话,很容易就掉到坑里了。比如下面的例子:用Lambda访问MSSqlServer中的NewsInfo表中id小于20的记录。
代码如下:
运行程序,程序工作正常。打开SQL Server Profiler 跟踪EF生成的SQL语句,结果如下:
这正是我们想要的SQL语句。下面我们将程序改一下,把Lambda表达式以参数的形式传递给一个方法GetNewsList(Func<NewsInfo, bool> lambda)。方法GetNewsList的代码如下:
Main()方法如下:
这时再次运行程序,程序工作正常,不过时间长了一些,用SQL Server Profiler跟踪,产生的SQL语句如下:
“坑”出现了,EF是直接从NewsInfo表中取出所有的数据到内存中,然后在内存中再做一次检索。显然,这样的方式在数据量小的时候并不太影响性能。但是在大数据量,高并发访问的时候,这种方式简直就是噩梦。
那么怎样改善呢?System.Linq.Expressions命名空间的Expression可以帮我们解决以上问题。修改后的GetNewsList()方法代码如下:
Main()方法不变。下面再次运行代码,并跟踪产生的SQL如下:
这下正常了。Expression<TDelegate>类可以以表达式目录树的形式将强类型 lambda 表达式表示为数据结构,从而在编译阶段产生我们想要的SQL代码。
相关文章推荐
- Entity FrameWork 中使用Lambda访问数据库性能优化
- Entity FrameWork 中使用Lambda访问数据库性能优化
- Entity FrameWork 中使用Lambda访问数据库性能优化
- Entity FrameWork 中使用Expression<Func<T,true>>访问数据库性能优化
- 面向程序员的数据库访问性能优化法则
- 抽丝剥茧数据库访问性能优化
- 面向程序员的数据库访问性能优化法则
- 数据库访问性能优化
- 面向程序员的数据库访问性能优化法则
- 面向程序员的数据库访问性能优化法则
- 数据库 优化临时表使用,SQL语句性能提升100倍
- 面向程序员的数据库访问性能优化法则
- Related to Oracle 面向程序员的数据库访问性能优化法则(转)
- 面向程序员的数据库访问性能优化法则
- 数据库访问性能优化
- 【SqlServer2005+ 查询优化】MSSQL优化SQL语句 提高数据库的访问性能
- 面向程序员的数据库访问性能优化法则
- 数据库访问性能优化(二)
- 数据库性能优化-2-不太建议使用相关子查询
- 数据库访问性能优化