首页 > 编程 > .NET > 正文

实战 .Net 数据访问层 - 11

2024-07-10 13:03:21
字体:
来源:转载
供稿:网友
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;

}

...

}


发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表