专栏首页张善友的专栏Entity Framework(EF) 5

Entity Framework(EF) 5

在Entity Framework宣布开源后不久Entity Framework(EF) 5就正式发布了,ADO.NET官方博客上EF5 Released列出了EF5的新特性:

兼容性方面支持Visual Studio 2010 和 Visual Studio 2012 上的 .NET 4.0 和4.5应用项目。

微软已经发布了一份白皮书,概述使用Entity Framework 5(它作为.NET 4.5的一部分发布)时应关注的各种性能注意事项。

以下是一些需要注意的地方:

  • 冷查询执行vs.暖查询执行(Cold-vs-Warm query execution)——视图生成这一步(用于从数据库模式到概念模式或从概念模式到数据模式的必要转换)会增加第一次运行查询时的开销,后续运行会因为视图缓存的缘故会更快一些。用户可以通过预生成视图来提升性能
  • 缓存——在对象层次(特别是结合禁用AutoDetectChanges改善DbContext Find()性能),可用的缓存有查询计划缓存(Query Plan Caching)、元数据缓存(MetaData Caching)及结果缓存(Results Caching)。EF仍然没有提供二级缓存,不过我们可以参考一些指南进行实现——如CodePlex上的示例,以及Julia Lerman的文章“Entity Framework与Windows Azure中的二级缓存”;
  • 可选的无跟踪查询(没有状态跟踪的开销)。目前该选项只对ObjectQuery可用,没法适用于DbSet及DbQuery类;
  • 微型ORM风格的快速查询,如数据库上执行SQL查询以及ExecuteStoreQuery
  • 设计时注意事项——每个层次对应一张表(Table-per-hierarchy,简称TPH)vs. 每个类型对应一张表(Table-per-Type,简称TPT)vs. 每个类对应一张表(Table-per-Class,简称TPC);其中TPT在查询复杂度及性能方面表现最差;
  • 延迟加载vs.预先加载 (Lazy-vs-Eager loading)。

Entity Framework是由微软提供的一款面向.NET应用程序的商业对象关系映射框架。除了EF之外,.NET开发人员还可以选择的一些(开源和商业包括在内)产品有NHibernateLightSpeed。另外,还有一些轻量级的微型ORM模型像Dapper.NETPetaPocoMassive

Entity Framework 5.0系列之约定配置

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ASP.NET MVC 2示例Tailspin Travel

    Tailspin Travel 是一个旅游预订的应用程序示例,最新版本采用ASP.NET MVC 2技术构建,主要使用 DataAnnotations 验证, ...

    张善友
  • .NET Framework 4.5.2 静默安装参数

    Microsoft .NET Framework 4.5.2 是针对 Microsoft .NET Framework 4、Microsoft .NET Fra...

    张善友
  • .NET的垃圾回收器

    后台垃圾回收器(GC),.NET 4.5服务器应用程序中会默认开启。 在32位的操作系统下,.NET堆大约是2GB。而使用64位的操作系统,微软认为使用10GB...

    张善友
  • NET Framework 版本和依赖关系

    原文:https://docs.microsoft.com/zh-cn/dotnet/framework/migration-guide/versions-a...

    CNXY
  • 机器学习技术类书单推荐

    机器学习技术类书单推荐,共11本: 《机器学习》 《图解机器学习》 《机器学习实战》【有电子版】 《机器学习系统设计》【有电子版】 《Python机器学习基础教...

    小莹莹
  • .NET 基金会项目介绍-DNN Platform

    DNN Platform 是属于 .Net 基金会的一个项目,本文将简要介绍该项目相关的信息。

    newbe36524
  • 深圳软件测试学习:【数据库】-【oracle】-连接查询--千锋

    Select * from emp e,dept d where e.deptno=d.deptno;

    深圳java培训技术
  • 为什么Vitess推荐每个MySQL服务器250GB?

    Vitess对数据库的可伸缩性有自己的看法。有些观点很少有争议,比如应该如何通过复制提供持久性,但是我发现一个有趣的建议是每个MySQL服务器250GB。

    CNCF
  • 我是如何入门机器学习的呢

    机器学习在很多眼里就是香饽饽,因为机器学习相关的岗位在当前市场待遇不错,但同时机器学习在很多人面前又是一座大山,因为发现它太难学了。在这里我分享下我个人入门机器...

    abs_zero
  • 机器学习用于安全领域的5大案例

    AI和机器学习将极大改变安全运作方式,虽然目前正处在驱动网络防御的早期阶段,但已经在终端、网络、欺诈或SIEM中,起到了识别恶意活动模式的明显作用。未来,在防御...

    BestSDK

扫码关注云+社区

领取腾讯云代金券