Entity Framework 学习高级篇2—改善EF代码的方法(下)(转)
本节,我们将介绍一些改善EF代码的方法,包括编译查询、存储模型视图以及冲突处理等内容。
l CompiledQuery
提供对查询的编译和缓存以供重新使用。当相同的查询需要执行很多遍的时候,那么我们可以使用ComplieQuery将查询的语句进行编译以便下次使用,这样可以免去对同一语句的多次处理,从而改善性能。
示例代码如下:
[Test]
public void ComplieTest()
{
using (var db = new NorthwindEntities1())
{
//对查询进行编译
var customer = CompiledQuery.Compile<NorthwindEntities1, IQueryable<Customers>>(
(database) => database.Customers.Where(c => c.City == "London"));
//执行20次相同的查询
for (int i = 0; i < 20; i++)
{
DateTime dt = System.DateTime.Now;
foreach (var c in customer(db))
Console.WriteLine(c.CustomerID);
Console.WriteLine(DateTime.Now.Subtract(dt).TotalMilliseconds);
Console.WriteLine("---------------------------------------------------");
}
}
}
l 存储模型视图
在EF中,当执行实体查询的时候,运行时首先将实体模型转换成ESQL视图,而ESQL视图则是根据msl文件来生成相应的代码。此外,ESQL视图包含了相应的查询语句。ESQL视图被创建后将在应用程序域中进行缓存以便下次使用。这个运行时生成存储模型视图是比较耗时的过程。
为了,免去运行时生成存储模型视图,我们可以预先产生这个的存储模型视图。具体步骤如下:
首先,使用EdmGen2来产生存储模型视图,相应的命令如下:
Edmgen2 /ViewGen cs NorthwindEntites.edmx
执行此命令后,edmgen2会在当前目录下生成一个名为NorthwindEntites.GeneratedViews.cs这个文件,就是我们要使用的存储模型视图文件。
将此文件添加到项目中就行,其他的代码不需要改变,EF会自动调用此视图文件。如下示例代码:
[Test]
public void ViewTest()
{
using (var db = new NorthwindEntities1())
{
var suppliers = db.Suppliers;
foreach (var s in suppliers)
Console.WriteLine(s.ContactName);
}
}
没有使用存储模型视图的情况是:
1 passed, 0 failed, 0 skipped, took 7.09 seconds.
项目中添加了NorthwindEntites.GeneratedViews.cs文件,执行情况是:
1 passed, 0 failed, 0 skipped, took 5.38 seconds.
可见,使用了存储模型视图的确是提高了性能。
l 冲突处理
在EF中,默认情况并不会检查并发冲突。因为EF实现的是乐观的并发模式,当有并发的冲突发生时,将会抛出Optimistic Concurrency Exception异常。我们可以通过使用RefreshMode这个枚举来指定当发生冲突时如何处理。
RefreshMode有两中枚举值:
ClientsWins: 当提交修改,更新数据库中的值。
StoreWins: 放弃修改,使用数据库中的值。
示例代码片段如下:
var db2 = new NorthwindEntities1();
var customer2 = db2.Customers.FirstOrDefault(c => c.CustomerID == "2009");
if (customer2 != null)
{
customer2.ContactName = "♂风车车.Net";
customer2.City = "CD";
customer2.Region = "GX";
}
try
{
db2.SaveChanges();
}
catch (OptimisticConcurrencyException ex) //捕获到冲突,则进行相应的处理
{
db2.Refresh(RefreshMode.ClientWins, customer2);
db2.SaveChanges();
}
上述代码片段,只是说明怎么处理并发冲突,不是具体的并发。(ps:本来是准备开个线程来模拟并发的,但是始终没成功,没明白什么原因,望高人指点呢!)
转载于:https://www.cnblogs.com/quietwalk/archive/2011/07/02/2096366.html
Entity Framework 学习高级篇2—改善EF代码的方法(下)(转)相关推荐
- Entity Framework 学习高级篇2—改善EF代码的方法(下)
本节,我们将介绍一些改善EF代码的方法,包括编译查询.存储模型视图以及冲突处理等内容. l CompiledQuery 提供对查询的编译和缓存以供重新使用.当相同的查询需要执行很多遍的 ...
- Entity Framework 学习高级篇1—改善EF代码的方法(上)
本节,我们将介绍一些改善EF代码的相关方法,如NoTracking,GetObjectByKey, Include等. l MergeOption.NoTracking 当我们只需要读 ...
- oracle数字类型ef映射,Entity Framework 学习中级篇5—使EF支持Oracle9i - ♂风车车.Net - 博客园...
从Code MSDN上下载下来的EFOracleProvider不支持Oracle9i.但是,目前我所使用的还是Oracle9i.为此,对EFOracleProvider修改了以下,以便使其支持Ora ...
- Entity Framework 学习中级篇1—EF支持复杂类型的实现
本节,将介绍如何手动构造复杂类型(ComplexType)以及复杂类型的简单操作. 通常,复杂类型是指那些由几个简单的类型组合而成的类型.比如:一张Customer表,其中有FristName和Las ...
- Entity Framework 学习中级篇—EF支持复杂类型的实现
http://www.cnblogs.com/xray2005/archive/2009/06/01/1493661.html 本节,将介绍如何手动构造复杂类型(ComplexType)以及复杂类型的 ...
- Entity Framework学习中级篇
1-EF支持复杂类型的实现 本节,将介绍如何手动构造复杂类型(ComplexType)以及复杂类型的简单操作. 通常,复杂类型是指那些由几个简单的类型组合而成的类型.比如:一张Customer表,其中 ...
- 改善EF代码的方法(下)
本节,我们将介绍一些改善EF代码的方法,包括编译查询.存储模型视图以及冲突处理等内容. > CompiledQuery 提供对查询的编译和缓存以供重新使用.当相同的查询需要执行很多遍的时候,那么 ...
- python学习高级篇(part10)--类对象的特殊方法和特殊属性
学习笔记,仅供参考,有错必纠 文章目录 python 学习高级篇 类对象的特殊方法之`__del__()` 类对象的特殊方法之`__getattr__()` 类对象的特殊方法之`__getitem__ ...
- python学习高级篇(part8)--类对象的特殊方法
学习笔记,仅供参考,有错必纠 文章目录 python 学习高级篇 类对象的特殊方法之`__iter__()`和`__next__()` 类对象的特殊方法之`__add__()`和`__radd__() ...
- python学习高级篇(part7)--特殊属性和特殊方法
学习笔记,仅供参考,有错必纠 文章目录 python 学习高级篇 特殊属性和特殊方法 获取对象的信息之特殊属性`__dict__` 获取对象的信息之反射 类对象的特殊方法`__len__()` pyt ...
最新文章
- 不要再用arxiv链接了!为了让论文引用更规范,上交毕业生、南加州大学华人博士创建了一个小工具...
- Elasticsearch总体介绍
- 研究人员发现利用Excel宏可发起跳板攻击
- Android 4.0新增WiFiDirect功能
- charles 简单使用
- Base64 编码介绍
- SSL introduce itself from baidu
- Answers To The Questions from GiGabyte
- Visual Studio自动生成XML类和JSON类
- PV操作经典例题——和尚打水
- Vim文件和日历操作
- 项目结构优化设计之smv架构
- Big Sur + karabiner + kernelmanagerd = 可能发烫
- SSR和CSR的区别
- 408计算机网络学习笔记——应用层
- IP地址,子网,掩码的计算
- 基于Qt的酒店管理系统(毕业设计)
- 5GNR R17 PLMN选择和SNPN选择
- 这些阿里、京东、美团的面试题 你都会吗?
- 最全最详细的大数据组件介绍
热门文章
- C#反射的Assembly的简单应用
- 微软ReportViewer(rdlc)发布时所需要的动态库(vs2010)
- [转载+整理]Nginx Location匹配规则
- 【c++】函数默认参数
- Excel的实用函数
- 具体解说Android的图片下载框架UniversialImageLoader之磁盘缓存(一)
- java 图形化界面 布局管理器
- cocos2d-x学习之旅(九): 2.2 盘古开天辟地,进入游戏世界
- 关于nginx性能优化CPU参数worker_cpu_affinity使用说明
- Laser Reflections solutions