- 热门文章:
- · 实战 .Net 数据访问层 - 4
- · 实战 .Net 数据访问层 - 3
- · 实战 .Net 数据访问层 - 2
- · .Net里的序列化
- · 从在 Internet Explorer 中使用 Windows 窗体控件开始谈Smart Client
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(4)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(3)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(2)
- · 关于何种情况下使用DataGrid、DataList或Repeater的一些讨论(1)
- · Csharp+Asp.net系列教程(三)
- · Csharp+Asp.net系列教程(二)
- · 设计模式之代理模式(Proxy)
上一篇:可以搜索的ComboBox---- >>
实战 .Net 数据访问层 - 5
// 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=27548
下一篇:实战 .Net 数据访问层 - 4 >>
相关文章:
- · 弹出对话框的同时保持页面的显示
- · ASP.Net中使用VB.Net调用存储过程并得到返回值
- · 改变文本框、按钮样式函数
- · 使用Asp.Net中的XmlValidatingReader来验证XML Schema.
- · 用asp.net 实现“九连环” 小游戏
- · ASP.Net中使用VB.Net调用存储过程并得到返回值
- · ASP.NET 的亲密朋友之--javascript
- · 如何开发一个可复用的软件系统
- · 在ASP.NET中显示进度条
- · 路由模拟——类设计的声明部分
- · 如何重新设置DataSet中的DataTable对象
- · 用NUnit2.1简单实现.net的测试驱动开发(TDD)
- · ASP.NET中的STREAMREADER对象总结
- · ASP.NET中的STREAMREADER对象总结
- · ASP.NET中的FILESTREAM对象总结
- · ASP.NET中的FILE对象总结
- · asp.net中常用的一些小技巧
- · DataGrid删除确认及Item颜色交替
- · asp.net生成缩略图
- · 设计模式之单件模式(Singleton Pattern )
- · 设计模式之简单工厂模式(Simple Factory Pattern)
- · 如何在asp.net页面上放置的控件上实现左右键菜单,同时对之操作(2)
- · 设计模式之观察者模式(Observer Pattern)(二)
- · 设计模式之观察者模式(Observer Pattern)(一)
- · 1. 一个类似于Calendar日期控件,不用再刷新页面。
- · 一个完美的日期控件 + 一个用脚本断判日期型的方法(1)
- · 使用DataGrid动态绑定DropDownList
- · .NET 1.1中预编译ASP.NET页面实现原理浅析 [1] 自动预编译机制浅析
- · 利用ASP.NET服务器端自定义控件实现XML文件中还原表单
- · .NET概观
- · ASP.NET中的Http Handles
- · Asp.net性能优化总结(二)
- · 一个非常实用的Base64类
- · 在asp.net中为Web用户控件添加属性和事件
- · 使用.NET实现断点续传(HTTP)
- · .NET 脚本(二)
- · .NET 脚本
- · ASP.NET分页组件更新版本
