ICANN认证国际域名顶级注册机构
网站建设,域名注册,空间租用,软件销售,广告设计 域名注册,空间租用, 网站建设,东莞网页设计,域名注册,网站推广,网站开发,网页设计 网站推广,,百度推广,新浪推广,雅虎推广,网易推广 标志设计,画册设计,包装设计,VI策划,企业形象顾问 连邦软件加盟店,提供销遥行,管家婆,速达,用友ERP,诺顿等软件报价及销售 建站必读 腾达网络,上网帮助中心, 腾达为东莞等地,提供网站建设,网站推广,广告设计,软件销售等优质服务!
建站必读


 
 
当前位置:首页 -> 建站必读 -> .NET技术
实战 .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;







// Collection fields



protected internal ArrayList _al = null;



protected internal Hashtable _ht = null;







// ADO.NET fields



protected internal DataSet _dst = null;



protected internal DataTable _tbl = null;



[NonSerialized()]



protected internal DbDataReader _rdr = null;







public DefBase() { }



public DefBase(ArrayList al)



{



this._al = al;



this._typeEntity = EntityType.COLLECTION_ARRAYLIST;



}



...



public DefBase(DataSet dst)



{



this._dst = dst;



this._typeEntity = EntityType.ADOX_DATASET;



}



public DefBase(DataTable tbl)



{



this._tbl = tbl;



this._typeEntity = EntityType.ADOX_TABLE;



}



...



}



































































































































































以上,就是我的Data Entity小样了(终于又要见人了J),是不



是感觉很“酷”啊?



坦率地讲,根据我的保守估计,八成以上的朋友会有“不敢苟同”之想法,而另外15%可能是不能确定,总有似曾相识(四不象?)却又不尽相同的味道。至于这剩下的5%,我就不是很清楚了(希望是所见略同吧),如果哪位写邮件告诉我“这正是我想要的,请你给我一份源码吧”,估计我会毫不犹豫的立即奉上而不再考虑任何License问题(如果在1天内没有收到回复,请您相信是作者开心得晕过去了,要不就是Internet出问题了J)!







Ok,简单解释一下:



可能大家已经注意到一个问题,这里的Def好像并不是Data



Entity的缩写,那么,这个“f”到底代表什么呢?



前面曾经提过,作者的这个数据访问层解决方案起名字为Data Access Façade(DAF),参考的当然是GOF23条中的Façade Pattern,所以,有鉴于此,这里Def中的“f”同样包含着Façade意思!







是不是有点复杂了?头晕?没有关系,且听一一道来!







代码2中给出的两种经典Data Entity模式各有其明显的优缺点,基本上,就作者了解的情况,实际开发中都是以一种统一的方式进行抉择,难免就顾此失彼(总有些Case是简单的,也总有些Case是让人头疼不已的)。如果,再加上系统架构时必须考虑的其它因素,如:安全,性能,可扩展性(接口/基类),可伸缩性(负载均衡/分布式处理)等,对于一个稍微上点规模的Enterprise Application,也就不难理解为何Data Access Layer总是那么让人又爱又恨了(Sigh,Data Entity才只是万里长征第一步啊L)!







所以,为了解决这个问题,作者感觉有必要搞一个相对比较Generic的解决方案,所要解决的第一个问题就是:Data Entity!



所谓的Def,当然就是:Data Entity Façade,说白了,就是以一



致的方式将数据展现在您的面前!这里的一致,不仅仅意味在当前应用程序中表现出一致的访问方式(Interface),还要能够确保在一致的Interface下支持不同的Data Entity模型(Storage)。而所有这一切,都被隐藏在了一个特别搭建的Data Entity之后,它,就是作者DAF解决方案中的第一步:Data Entity Façade!简称为:Def。







下一段:http://www.csdn.net/develop/Read_Article.asp?id=
 
 
本站关键词:
|东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作||东莞专业网络公司|东莞速达软件|东莞财务软件|东莞ERP软件|东莞电脑维护|东莞网站建设|东莞网页设计|东莞网络公司|网站建设|网页设计|网络公司|网站制作|
域名注册 | 虚拟主机 | 网站建设 | 网站推广 | 广告设计 | 帮助中心 | 软件中心 | 关于腾达
东莞市腾达信息工程有限公司      本站网络实名: 东莞网站建设
地址:东莞市新城市中心区第一国际B座610   邮编:523007
电话:0769-22026071 22026072 传真:0769-22026076 24小时服务热线:13712032014
© 2002~2005 腾达网络   版权所有