欢迎光临
我们一直在努力

实战 .Net 数据访问层 – 3-.NET教程,Asp.Net开发

建站超值云服务器,限时71元/月

2. data entity façade

代码2:传统data entity

// customer1:包含基本字段的customer,属轻量级data entity

[serializable()]

public class customer1: xxx // xxx表示可能存在的基类

{

public string id;

public string name;

public string phone;

public customer1() {…}

}

// customer2:从dataset继承的customer,又称typed dataset

[serializable()]

public class customer2 : system.data.dataset

{

private customersdatatable tablecustomers;

private ordersdatatable tableorders;

private datarelation relationfk_orders_customers;

public customer2() {…}

}

实际上,还有一些方案中可能采用了混合模式,比如:虽然从

dataset继承(简单的可以直接从datatable继承),但只实现typed

dataset的部分功能;或者,虽然包含了基本字段,但在内部实现了

数据填充或转换(在petshop中,数据通过dal以reader方式获取

并填充至data entity,并没有直接使用data entity进行转换);还有

一种最彻底的方式:直接采用reader作为data entity进行cross

layer数据交换!这样,性能是最高了,但也给其它layer开发人员

带来了一些不必要的烦恼l。

对于只包含基本字段的data entity,使用起来非常简单,同时还

能以自己比较熟悉的方式编写程序,然而,付出的代价也不小:对

于比较复杂的case,处理起来就不那么得心应手(即使framework

提供了这些功能,却很不ease of use,这个可从borland eco所带

的ocl中略知一二,.net framework objectspaces中所带的opath

也是半斤八两l)!

幸好,上述的缺点正是typed dataset之强项!

虽然体形庞大,但不失灵活,这就是ado.net带给我们的“礼

物”j不得不承认,用typed dataset虽然可能导致一系列问题(性

能,维护),但有时候我们还真是愿意体会这种“痛,并快乐着”的

感觉(当然了,这种感觉并不仅仅限于处理复杂case时的ease of use

体验)!

duwamish这样做了,作者的前一个项目也这样做了,您是不是

也准备这样做呢(系统架构师们不定又要大发雷霆了j)?

ok,说这么多,就一个目的:当然是“隆重推出”作者自己“苦

心孤诣”多年却被“无数”系统架构师“否决”的data entity!实战

没机会,管它呢,先发个稿子到这里,待大家一起讨论讨论,看看

是否有出头之日j。

下一段:http://www.csdn.net/develop/read_article.asp?id=27546

赞(0)
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com 特别注意:本站所有转载文章言论不代表本站观点! 本站所提供的图片等素材,版权归原作者所有,如需使用,请与原作者联系。未经允许不得转载:IDC资讯中心 » 实战 .Net 数据访问层 – 3-.NET教程,Asp.Net开发
分享到: 更多 (0)