使用Entity Framework 5的性能注意事项
fmms 13年前
<div id="news_body"> <p> 虽然 Entity Framework (EF) 5 承诺带来了超越 EF 4 的<a href="/misc/goto?guid=4958330124940715375">大幅性能提升</a>,但为了更有效地使用 ORM,我们仍然需要关注一些注意事项——即视图生成、缓存、自动编译的查询、查询执行选项及设计时(Design Time)。</p> <p> 微软已经发布了一份<a href="/misc/goto?guid=4958338559269517558">白皮书</a>,概述使用待发布的 Entity Framework 5(它将作为即将到来的 .NET 4.5 的一部分发布)时应关注的各种性能注意事项。</p> <p> 以下是一些需要注意的地方:</p> <ul> <li>冷查询执行 vs. 暖查询执行(Cold-vs-Warm query execution)——视图生成这一步(用于从数据库模式到概念模式或从概念模式到数据模式的必要转换)会增加第一次运行查询时的开销,后续运行会因为视图缓存的缘故会更快一些。用户可以通过<a href="/misc/goto?guid=4958338560080477618">预生成视图来提升性能</a>;</li> <li>缓存——在对象层次(特别是结合禁用 AutoDetectChanges 改善 DbContext Find ()性能),可用的缓存有查询计划缓存(Query Plan Caching)、元数据缓存(MetaData Caching)及结果缓存(Results Caching)。EF 仍然没有提供二级缓存,不过我们可以参考一些指南进行实现——如 <a href="/misc/goto?guid=4958338560877036190">CodePlex 上的示例</a>,以及 Julia Lerman 的文章“<a href="/misc/goto?guid=4958328959420919136">Entity Framework 与 Windows Azure 中的二级缓存</a>”;</li> <li>可选的无跟踪查询(没有状态跟踪的开销)。目前该选项只对 ObjectQuery 可用,没法适用于 DbSet 及 DbQuery 类;</li> <li>微型 ORM 风格的快速查询,如<a href="/misc/goto?guid=4958338562419781669">数据库上执行 SQL 查询</a>以及 <a href="/misc/goto?guid=4958338563216167035">ExecuteStoreQuery</a> ;</li> <li>设计时注意事项——每个层次对应一张表(Table-per-hierarchy,简称 TPH)vs. 每个类型对应一张表(Table-per-Type,简称 TPT)vs. 每个类对应一张表(Table-per-Class,简称 TPC);其中 TPT 在查询复杂度及性能方面表现最差;</li> <li>延迟加载 vs. 预先加载 (Lazy-vs-Eager loading)。</li> </ul> <p> <a href="/misc/goto?guid=4958338564021220359">Entity Framework</a> 是由微软提供的一款面向 .NET 应用程序的商业<a href="/misc/goto?guid=4958194314991416867">对象关系映射框架</a>。除了 EF 之外,.NET 开发人员还可以选择的一些(开源和商业包括在内)产品有 <a href="/misc/goto?guid=4958338565555230962">NHibernate</a> 和 <a href="/misc/goto?guid=4958338566358068372">LightSpeed</a>。另外,还有一些轻量级的微型 ORM 模型像 <a href="/misc/goto?guid=4958338567151267256">Dapper.NET</a>、<a href="/misc/goto?guid=4958338567947138299">PetaPoco</a> 及 <a href="/misc/goto?guid=4958338568760122485">Massive</a>。</p> <p> <strong>查看英文原文:</strong><a href="/misc/goto?guid=4958338569557121010">Entity Framework 5 - Performance Considerations</a><a href="/misc/goto?guid=4958338564021220359">Entity Framework</a></p> <div id="come_from"> 来自: <a id="link_source2" href="/misc/goto?guid=4958338571109771182" target="_blank">InfoQ</a> </div> </div>