实战 .Net 数据访问层 - 11

访问|数据

4. Data Access Logic

讨论Data Access Logic(为了不和Data Access Layer混淆,文中

所有涉及Data Access Logic的部分将全部使用全称描述,DAL仅指Data Access Layer)前,让我们先看一看它的结构示意图:

咦!怎么回事?看上去长得与DAF非常相似嘛!难道这就是作

者“不辞辛劳”单独开辟一个小节来进行“大肆宣传”的Data Access

Logic吗?

没错!这就是Data Access Logic!它是和DAF长得有点像,但

绝对不是孪生兄弟,它所起的作用也和DAF完全不同!

首先需要声明的是,Data Access Logic与DAF间的相似性确实

存在,但也就体现在如下两个方面(作者认为这并不是其主要特性):

(1) 它们都采用了2次继承模式;

(2) Data Access Logic的前两层(DalBase / MyDal)作用大致相当于DAF中的前两层作用,分别在Framework Level和Application Level提供一些基础服务。

但是,除此之外,作者需要特别强调的是,Data Access Logic的

关键特性并不在这前两层(DAF则有点不同,它的前两层非常重要),

而是在真正实现了具体Data Access Logic的第3层中!

打个简单比方:DAF有点像.NET中的Interface,而Data Access Logic则更像ImplementationJ。

那么,作者为何不直接将DAF声明为Interface而令Data Access Logic直接继承之呢?到底是什么原因令我们必须将它们严格分开,并在不同的Layer中进行处理呢?

其实,原因在上面已经分析了一部分(DAF需要确保接口声明一致,数据实体一致,而Data Access Logic则无此限制),另一部分原因则在于,DAF对外需要统一公布所有接口,而Data Access Logic则可以相对灵活地进行不同处理。例如:可以将ADO.NET相关的数据访问操作集中在一个地方,而XML相关的处理放置则可以在另一个地方进行实现(是不是更有利于细化分工J)!

还有两种情况可能也需要支持这种变化:

(1) 当前版本中,我们使用了某种方法实现Data Access Logic,例如:O/R Mapping,可是在后续版本中,由于某些原因(性能/复杂度),我们需要改用DataSet方式进行交互,这时候,我们为DataSet撰写的新方法就可以非常方便的替换现有的O/R Mapping方法(只要修改一下配置信息),而对外接口(DAF)则根本不必修改(当然了,原来针对O/R Mapping返回数据进行处理的那些代码是必须要修改的,但这并不会破坏Cross Layer间的接口一致性)!

(2) 系统中可能会存在一些遗留Data Access Logic代码,这部分东东弃之可惜,食之则余香依旧,怎么办呢?很简单,交给DAF处理吧!我们可以单独建立一个Data Access Logic模块(例如:CustomerDal_LEGACY)专门包含这部分代码,然后,在DAF中使用Adapter Pattern将其统统归入门下(当然了,也可以在这个专用Data Access Logic模块中直接包装,但作者更喜欢使用DAF干这样的杂事J)!

Ok,文字看累了,来段代码瞅瞅:

代码9:掀起Data Access Logic的盖头来!

// DalBase:提供大部分应用程序所需的基本数据访问支持,

// 包括分布式处理,数据缓存支持等

public class DalBase

{

public DalBase() { }

protected string GetDistributionType()

{

string strType = null;

... // 根据当前调用上下文和配置文件得到所需数据

return strType;

}

protected CacheParam GetCacheParam()

{

CacheParam param = null;

... // 根据当前调用上下文和配置文件得到所需数据

return param;

}

...

}

时间: 2024-09-15 18:00:55

实战 .Net 数据访问层 - 11的相关文章

实战 .Net 数据访问层 - 1

访问|数据 实战 .Net 数据访问层 l 特别说明 本篇实战共分23段,非作者有意如此,乃受CSDN发表文章之64K所限. 虽然有几段根本没有达到64K,但估计是HTML Source超过了这个范 围,所以也不得不单独分段(大都是源代码),请大家谅解. 如果有朋友需要完整文档,请发邮件给我: mailto:xuefeng.zhang@bearingpoint.com l 引言 这次的讨论是上一部分"剖析 .Net 下的数据访问层技术"的一个续,但也可独立成章,为突出主题,作者就特意换

实战 .Net 数据访问层 - 23

访问|数据 u 使用现成的框架 Ø 首选当然是.NET Framework即将正式推出的ObjectSpaces! Ø 如果希望Total Solution,Borland ECO就是最佳选择! Ø 其它 n 开源项目推荐使用OPF(国外) n 商业产品推荐使用Grove(国内) u 设计自己的持久层 Ø 如果希望自己设计轮子,那么,最好的参考资料莫过于这篇文章:http://www.ambysoft.com/persistenceLayer.pdf Ø 它山之石,可以攻玉 此处之它山,非J2E

实战 .Net 数据访问层 - 5

访问|数据 代码4:我的Data Entity – 2,Framework中的Data Entity // DafBase:提供大部分应用程序所需的基本Data Entity支持, // 包括Collection,ADO.NET [Serializable()] public abstract class DefBase : IList, IDictionary { protected internal string _typeEntity = EntityType.OBJECT; // Col

实战 .Net 数据访问层 - 12

访问|数据 从这个DalBase很容易看出,Framework Level的支持主要集中 在Cache Management和Distributed Process上面,这也几乎是所 有Data Access Logic都不得不考虑的现实问题(可能在实际项目中, Data Access Logic Level的Distributed Process需求不会很多,大部分 都在Business Logic中直接解决了)! 以下,就让我们看看制造一个真正的Data Access Logic是多么的 方

实战 .Net 数据访问层 - 22

访问|数据 Ok,在结束整个"我的方案"之前,作者最后"献上"一段代 码(是不是有点晕了?),希望能为您的DAF之旅划上一个圆满的句号J 代码17:通过DAF更新数据 // 创建Customer数据访问对象 CustomerDaf daf = new CustomerDaf(); // 创建Customer数据实体对象,设置对象字段值 Customer cust_1 = new Customer(); cust_1.Id = "ALFKI"; c

实战 .Net 数据访问层 - 10

访问|数据 以下是DAF的结构示意图: 是不是看上去还比较简单? 根据以往的经验判断,在这种继承模式下,主要的开发工作全部集中到了DafBase和MyDaf身上,CustomerDaf的任务相对轻松,数据校验或者转换处理也并不是每个方法都需要的J 那么,DAF既然号称Façade,除了满足Façade之必要条件,还要起很好的表率作用,为上面的Data Entity Façade和下面的Data Access Layer作出一个榜样(也是一个桥梁),以下就是作者总结出的4大要素: (1) 所有的数

实战 .Net 数据访问层 - 18

访问|数据 谈了些实现问题,来说说几个题外话: (1) 性能问题:Cache Management能显著提高数据访问效率,但对内存的要求比较高,尤其是在Web Application或Remoting Server这种应用环境下! 所以,这就要求我们应该将"钱"用在"刀刃"上(对内存毫不在乎者除外J),不能乱花钱! 一般,对于系统数据(如:应用 / 模块,组 / 用户 / 权限等)或Lookup Data(如:婚姻状况列举 / 政治面貌列举等),可以考虑放入Cach

实战 .Net 数据访问层 - 16

访问|数据 5. Cache Management 首先说明一点,之所以将Cache Management单列出来,就 是为了要说明数据缓存的重要性!在很多时候,这比撰写Data Access Logic更让人费心,也更令人难以把握. 作者的这个Cache Management实现了进行Data Cache时所 必须考虑的几个问题,虽然还并不完善,但也可在实战中运用了! 以下,就是它的结构示意图: 从图中,可以很明显地看到,这个Cache Management方案 主要由3部分组成:Manage

实战 .Net 数据访问层 - 15

访问|数据 上面的示意图中,步骤7指向的Remoting Server就是Host程序, 而Remoting Server包裹着的RemoteCustomer就是真正提供服务的数 据操作类. 以下所列代码即为该类的部分实现: 代码13:使用Data Access Logic进行Remoting调用 – 3,RemoteCustomer public class RemoteCustomer: MarshalByRefObject { public RemoteCustomer() { } pub