日期:2012-04-05  浏览次数:20404 次

Ok,上面的DafBase只是个Abstract Base Class(ABC),请继续

看下面的真正Daf:



代码8:让DAF工作起来!

// MyDaf:提供当前应用程序所需的Data Access支持,从DafBase继承

public class MyDaf: DafBase

{

public MyDaf() { }



protected override DefBase CallDalMethod(

object[] paramsValue)

{

...

DefBase def = base.CallDalMethod(paramsValue);

...

return def;

}

}



// CustomerDaf:包含实际的数据访问方法声明,

// 通过调用DAL获取数据,从MyDaf继承

public class CustomerDaf: MyDaf

{

public CustomerDaf() { }



public MyCustomer GetCustomerById(string strId)

{

... // 检查或转换传入参数

MyCustomer cust = (MyCustomer)CallDalMethod(

new object[] { strId });

... // 对数据结果进行修改或转换

return cust

}



public MyCustomer GetCustomers(string strName)

{

... // 检查或转换传入参数

MyCustomer cust = (MyCustomer)CallDalMethod(

new object[] { strName });

... // 对数据结果进行修改或转换

return cust

}

...

}

















































































































统一的Data Access Logic调用推给DefBase完成(需要根据配置

信息进行一系列“枯燥无味”的处理),自定义部分才由自己来完成,

这就是MyDaf和CustomerDaf出现的真正原因!

MyDaf相当于当前Enterprise Application的数据访问基础,可以

针对应用程序的特点提供一些基本的服务,在此服务下,真正的

CustomerDaf就可以集中精力对具体的Data Access Logic(不同于

Business Logic)进行处理了,例如:数据访问前的基本校验,对返

回结果进行转换操作等。

根据Ease of Use原则,我们也可以绕过MyDaf这层,直接让

CustomerDaf从DafBase继承,在这种情况下,整个Inheritance

Hierarchy就显得更加简单了。