因为数据持久层选型,这段时间查阅了很多资料,也做了很多实验,感觉这个东西虽然很强大,但在做大型项目时还是缺少灵活性,主要在以下几个方面:
1、实体缓存支持不够灵活,虽然支持缓存,但必须对ObjectContext进行单例或多例管理,而且哪些缓存,哪些不缓存,缓存多少,如何刷新,都不是很完善;
2、ESQL不支持复杂的查询,这对于ERP之类的软件其实是个软肋;
3、如果要用edmx,分割和维护都是个麻烦事情;
4、如果表在不同的ObjectContext(也许是edmx),关联查询无法执行;
5、如果利用objectContext直接执行sql语句,返回的结果必须提供预先定义的实体类,不是很方便;
6、这个东东的延续性不是很好,微软解决一些缺点时不是在原有体系上兼容,而是另起炉灶,DbContext就有取代ObjectContext的趋势,虽然两个都可以用,还可以混合,但至少暴露出延续性是个问题,改过来还是需要一些成本的。
7、用实体这种强类型确实有利于编程,但在系统中,复杂的查询,特别是动态构造的查询没法使用,这是非常不利的。即不利于提高系统的灵活性,又没法减少工作量。
AEF从目前来看,功能的强大基本达到数据库系统级别:内存实体关系数据库。难道微软想用此替代SQLServer,Oracle?其实我到希望微软能在ADONet上提供一个数据库
方言处理的类库。
当然,AEF的优点很多,微软已经宣传的很多了,我就不说了.
至于测试驱动,代码优先,概念优先都是些忽悠人的东东(至少很有一部分),微软忽悠程序员,程序员忽悠老板,老板忽悠客户。
后记:我很赞同有些同仁的说法,我也发觉,我越是了解它,越觉得它是个又臭又长的家伙。
分享到:
相关推荐
学习ADO.NET Entity Framework的好文档。
Entity Framework完整版教程,从初级到中级,再到高级,循序渐进。
微软ado.net最新技术,实体框架(entity framework)扩展
数据ADO.NET sql、LINQ to sql、ADO.NET Entity Framework(EF)数据库连接性能比较,主要比较了插入与读取的时间,读取里可以进行模糊检索
ADO.NET Entity Framework 是微软以 ADO.NET 为基础所发展出来的对象关系对应 (O/R Mapping) 解决方案,该插件为4.1版本
ADO.NET Entity Framework使用封装示范代码,这个中封装可以提高开发效率
ADO.NET Entityframework dbcontext a
ADO.NET Entity Framework概述PPT讲解,已经学习,好东西、分享
最近ado.net entity framework 电子书,入门学习的最佳书籍
ADO.NET Entity Framework 增删改查语句句法
ADO.NET EntityFramework入门教程,分别讲解Storage Provider ,Mapping Layer ,Object Services,LINQ to Entities 四层如何设计使用
ADO.NET Entity Framework 入门示例向导
利用ADO.net entity framework+Linq实现的学习源代码---利用ADO.net entity framework+Linq实现的学习源代码
利用ado.net entity framework快速开发信息管理---利用ado.net entity framework快速开发信息管理
中新增的数据访问层设计技术ADO.NET Entity Framework。ADO.NET的LINQ to Entity部分以LINQ 为基础,为了完整性本文档首先介绍LINQ技术 Entity Framework 教程 目录 预备知识 2 LINQ技术 2 LINQ...
ADO.NET Entity Framework Domain-Driven
ADO.NET EntityFramework 实体完整版教程,从初级到中级,再到高级,循序渐进。
//作者:黄颢鹏,Email:anh3000@qq.com,转载请注作者名 ADO.NET Entity Framework 的分页类代码.rar
WPF+ADO.net Entity Framework 抽奖程序源码